Diff for /loncom/interface/coursecatalog.pm between versions 1.53.4.4 and 1.75

version 1.53.4.4, 2010/02/12 00:21:30 version 1.75, 2013/11/20 18:40:09
Line 66  sub handler { Line 66  sub handler {
     }      }
     my $formname = 'coursecatalog';      my $formname = 'coursecatalog';
     if ($env{'form.showdom'} ne '') {      if ($env{'form.showdom'} ne '') {
           $env{'form.showdom'} = &LONCAPA::clean_domain($env{'form.showdom'});
         if (&Apache::lonnet::domain($env{'form.showdom'}) ne '') {          if (&Apache::lonnet::domain($env{'form.showdom'}) ne '') {
             $codedom = $env{'form.showdom'};              $codedom = $env{'form.showdom'};
           } else {
               $env{'form.showdom'} = '';
         }          }
     }      }
     my $domdesc = &Apache::lonnet::domain($codedom,'description');      my $domdesc = &Apache::lonnet::domain($codedom,'description');
     &Apache::lonhtmlcommon::clear_breadcrumbs();      &Apache::lonhtmlcommon::clear_breadcrumbs();
   
       if ($env{'form.catalog_maxdepth'} ne '') {
           $env{'form.catalog_maxdepth'} =~ s{\D}{}g;
       }
   
     my %domconfig =      my %domconfig =
         &Apache::lonnet::get_dom('configuration',['coursecategories'],$codedom);          &Apache::lonnet::get_dom('configuration',['coursecategories'],$codedom);
     my (@cats,@trails,%allitems,%idx,@jsarray,%subcathash,$cathash);      my (@cats,@trails,%allitems,%idx,@jsarray,%subcathash,$cathash);
Line 87  sub handler { Line 94  sub handler {
     }      }
     &Apache::loncommon::extract_categories($cathash,\@cats,\@trails,\%allitems,      &Apache::loncommon::extract_categories($cathash,\@cats,\@trails,\%allitems,
                                            \%idx,\@jsarray,$subcats);                                             \%idx,\@jsarray,$subcats);
       my ($numtitles,@codetitles);
     if ($env{'form.coursenum'} ne '' && &user_is_known()) {      if ($env{'form.coursenum'} ne '' && &user_is_known()) {
         &course_details($r,$codedom,$formname,$domdesc,\@trails,\%allitems);          &course_details($r,$codedom,$formname,$domdesc,\@trails,\%allitems,\@codetitles);
     } 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 $catjs = <<"ENDSCRIPT";          my $catjs = <<"ENDSCRIPT";
   
 function setCatDepth(depth) {  function setCatDepth(depth) {
Line 113  function setCourseId(caller) { Line 122  function setCourseId(caller) {
 }  }
   
 ENDSCRIPT  ENDSCRIPT
         $catjs .= &courselink_javascript();           $catjs .= &courselink_javascript();
         my $numtitles;          if (&user_is_dc($codedom)) {
               $catjs .= <<ENDTOGGJS
   
   function toggleStatuses() {
       if (document.$formname.showdetails.checked) {
           document.getElementById('statuschoice').style.display='block';
           document.getElementById('statuscell').style.borderLeft='1px solid'; 
       } else {
           document.getElementById('statuschoice').style.display='none';
           document.getElementById('statuscell').style.borderLeft='0px';
       }
       return;
   }
   
   function toggleWasActive() {
       if (document.getElementById('counts_Previous')) {
           if (document.getElementById('counts_Previous').checked) {
               document.getElementById('choosewasactive').style.display='block';
               document.getElementById('choosewasacctext').innerHTML = '$wasacctext';
           } else {
               document.getElementById('choosewasactive').style.display='none';
               document.getElementById('choosewasacctext').innerHTML = '';
           }
       }
       return;
   }
   
   ENDTOGGJS
           }
         if ($env{'form.currcat_0'} eq 'instcode::0') {          if ($env{'form.currcat_0'} eq 'instcode::0') {
             $numtitles = &instcode_course_selector($r,$codedom,$formname,$domdesc,              $numtitles = &instcode_course_selector($r,$codedom,$formname,$domdesc,
                                                    $catlinks,$catjs);                                                     $catlinks,$catjs,\@codetitles);
             if ($env{'form.state'} eq 'listing') {              if ($env{'form.state'} eq 'listing') {
                 $r->print(&print_course_listing($codedom,$numtitles));                  $r->print(&print_course_listing($codedom,$numtitles,undef,undef,undef,
                                                   \@codetitles));
             }              }
         } else {          } else {
             my (%add_entries);              my (%add_entries);
Line 164  ENDJS Line 202  ENDJS
                           $display_button.'" /></form><br /><br />');                            $display_button.'" /></form><br /><br />');
             }              }
             if ($env{'form.state'} eq 'listing') {              if ($env{'form.state'} eq 'listing') {
                 $r->print(&print_course_listing($codedom,undef,\@trails,\%allitems,$subcats));                  $r->print(&print_course_listing($codedom,undef,\@trails,\%allitems,$subcats,\@codetitles));
             }              }
         }          }
     }      }
Line 173  ENDJS Line 211  ENDJS
 }  }
   
 sub course_details {  sub course_details {
     my ($r,$codedom,$formname,$domdesc,$trails,$allitems) = @_;      my ($r,$codedom,$formname,$domdesc,$trails,$allitems,$codetitles) = @_;
     my $output;      my $output;
     my %add_entries = (topmargin    => "0",      my %add_entries = (topmargin    => "0",
                        marginheight => "0",);                         marginheight => "0",);
Line 181  sub course_details { Line 219  sub course_details {
              &courselink_javascript().'</script>'."\n";               &courselink_javascript().'</script>'."\n";
     my $start_page =      my $start_page =
         &Apache::loncommon::start_page('Course/Community Catalog',$js,          &Apache::loncommon::start_page('Course/Community Catalog',$js,
                                            {                                         {'add_entries' => \%add_entries, });
                                              'add_entries' => \%add_entries,  
                                              'no_inline_link'   => 1,});  
     $r->print($start_page);      $r->print($start_page);
     if ($env{'form.numtitles'} > 0) {      if ($env{'form.numtitles'} > 0) {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
                 ({href=>"/adm/coursecatalog",                  ({href=>"/adm/coursecatalog",
                   text=>"Course/Community Catalog"});                    text=>"Course/Community Catalog"});
     }      }
       my $brtextone = 'Course listing';
       my $brtexttwo = 'Course details';
       if ($env{'form.currcat_0'} eq 'communities::0') {
           $brtextone = 'Community listing';
           $brtexttwo = 'Community details';
       }
     &Apache::lonhtmlcommon::add_breadcrumb      &Apache::lonhtmlcommon::add_breadcrumb
              ({href=>"javascript:document.$formname.submit()",               ({href=>"javascript:document.$formname.submit()",
               text=>"Course listing"},                text=>$brtextone},
              {text=>"Course details"});               {text=>$brtexttwo});
     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));      $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));
     $r->print('<br />'.&mt('Detailed course information:').'<br /><br />'.      $r->print('<br />');
               &print_course_listing($codedom,undef,$trails,$allitems).      if ($env{'form.currcat_0'} eq 'communities::0') {
           $r->print(&mt('Detailed community information:'));
       } else {
           $r->print(&mt('Detailed course information:'));
       }
       $r->print('<br /><br />'.
                 &print_course_listing($codedom,undef,$trails,$allitems,undef,$codetitles).
               '<br /><br />');                '<br /><br />');
     $r->print('<form name="'.$formname.'" method="post" action="/adm/coursecatalog">'.      $r->print('<form name="'.$formname.'" method="post" action="/adm/coursecatalog">'.
               '<a href = "javascript:document.coursecatalog.submit()">'.                '<a href = "javascript:document.coursecatalog.submit()">');
               &mt('Back to course listing').'</a>'.      if ($env{'form.currcat_0'} eq 'communities::0') {
           $r->print(&mt('Back to community listing'));
       } else {
           $r->print(&mt('Back to course listing'));
       }
       $r->print('</a>'.
               &Apache::lonhtmlcommon::echo_form_input(['coursenum','catalogfilter',                &Apache::lonhtmlcommon::echo_form_input(['coursenum','catalogfilter',
                                                        'showdetails','courseid']).'</form>');                                                         'showdetails','courseid']).'</form>');
     return;      return;
Line 233  END Line 286  END
 }  }
   
 sub instcode_course_selector {  sub instcode_course_selector {
     my ($r,$codedom,$formname,$domdesc,$catlinks,$catjs) = @_;      my ($r,$codedom,$formname,$domdesc,$catlinks,$catjs,$codetitles) = @_;
     my %coursecodes = ();      my %coursecodes = ();
     my %codes = ();      my %codes = ();
     my @codetitles = ();  
     my %cat_titles = ();      my %cat_titles = ();
     my %cat_order = ();      my %cat_order = ();
     my %cat_items;      my %cat_items;
Line 246  sub instcode_course_selector { Line 298  sub instcode_course_selector {
                        marginheight => "0",);                         marginheight => "0",);
     my ($jscript,$totcodes,$numtitles,$lasttitle) =       my ($jscript,$totcodes,$numtitles,$lasttitle) = 
         &Apache::courseclassifier::instcode_selectors_data($codedom,$formname,          &Apache::courseclassifier::instcode_selectors_data($codedom,$formname,
                            \%cat_items,\@codetitles,\%cat_titles,\%cat_order);                             \%cat_items,$codetitles,\%cat_titles,\%cat_order);
     my $js = '<script type"text/javascript">'."\n$jscript\n$catjs\n".      my $js = '<script type"text/javascript">'."\n$jscript\n$catjs\n".
               '</script>';                '</script>';
     if ($totcodes) {      if ($totcodes) {
         if (($env{'form.state'} eq 'listing') && ($numtitles > 0)) {          if (($env{'form.state'} eq 'listing') && ($numtitles > 0)) {
             $add_entries{'onLoad'} = 'setElements()';              $add_entries{'onLoad'} = 'setElements();';
           }
           if (&user_is_dc($codedom)) {
               $add_entries{'onLoad'} .= ' toggleStatuses();toggleWasActive();'
         }          }
         &cat_header($r,$codedom,$js,\%add_entries,$catlinks,$numtitles);          &cat_header($r,$codedom,$js,\%add_entries,$catlinks,$numtitles);
         my $cat_maxdepth = $env{'form.catalog_maxdepth'};          my $cat_maxdepth = $env{'form.catalog_maxdepth'};
Line 263  sub instcode_course_selector { Line 318  sub instcode_course_selector {
         if ($numtitles > 0) {          if ($numtitles > 0) {
             $r->print('<b>'.&mt('Choose which course(s) to list.').'</b><br />'.              $r->print('<b>'.&mt('Choose which course(s) to list.').'</b><br />'.
                       &Apache::courseclassifier::build_instcode_selectors($numtitles,                        &Apache::courseclassifier::build_instcode_selectors($numtitles,
                        $lasttitle,\%cat_items,\@codetitles,\%cat_titles,\%cat_order));                         $lasttitle,\%cat_items,$codetitles,\%cat_titles,\%cat_order));
         }          }
         $r->print('<input type="hidden" name="coursenum" value="" />'."\n".          $r->print('<input type="hidden" name="coursenum" value="" />'."\n".
                   '<input type="hidden" name="sortby" value="" />'."\n".                    '<input type="hidden" name="sortby" value="" />'."\n".
                   '<input type="hidden" name="state" value="listing" />'."\n".                    '<input type="hidden" name="state" value="listing" />'."\n".
                   '<input type="hidden" name="form.currcat_0" value="instcode::0" />'."\n".  
                   '<input type="submit" name="catalogfilter" value="'.                    '<input type="submit" name="catalogfilter" value="'.
                   &mt('Display courses').'" />'.                    &mt('Display courses').'" />'.
                   '<input type="hidden" name="numtitles" value="'.$numtitles.                    '<input type="hidden" name="numtitles" value="'.$numtitles.
Line 290  sub cat_header { Line 344  sub cat_header {
     my ($r,$codedom,$js,$add_entries,$catlinks,$numtitles) = @_;      my ($r,$codedom,$js,$add_entries,$catlinks,$numtitles) = @_;
     my $start_page =      my $start_page =
         &Apache::loncommon::start_page('Course/Community Catalog',$js,          &Apache::loncommon::start_page('Course/Community Catalog',$js,
                                        {                                         { 'add_entries' => $add_entries, });
                                          'add_entries' => $add_entries,  
                                          'no_inline_link'   => 1,});  
     $r->print($start_page);      $r->print($start_page);
       my $brtext = 'Course listing';
       if ($env{'form.currcat_0'} eq 'communities::0') {
           $brtext = 'Community listing';
       }
     if ($env{'form.state'} eq 'listing') {      if ($env{'form.state'} eq 'listing') {
         if ($numtitles > 0) {          if ($numtitles > 0) {
             &Apache::lonhtmlcommon::add_breadcrumb              &Apache::lonhtmlcommon::add_breadcrumb
                 ({href=>"/adm/coursecatalog",                  ({href=>"/adm/coursecatalog",
                   text=>"Course/Community Catalog"},                    text=>"Course/Community Catalog"},
                  {text=>"Course listing"});                   {text=>$brtext});
         } else {          } else {
             &Apache::lonhtmlcommon::add_breadcrumb              &Apache::lonhtmlcommon::add_breadcrumb
             ({text=>"Course listing"});              ({text=>$brtext});
         }          }
     } else {      } else {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
Line 310  sub cat_header { Line 366  sub cat_header {
           text=>"Course/Community Catalog"});            text=>"Course/Community Catalog"});
     }      }
     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));      $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));
     my $onchange;      my $onchange = 'this.form.submit()';
     unless (($env{'browser.interface'} eq 'textual') || ($env{'form.interface'} eq 'textual')) {  
         $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><td><b>'.&mt('Domain:').'</b></td><td>'.
               &Apache::loncommon::select_dom_form($codedom,'showdom','',1,$onchange));                &Apache::loncommon::select_dom_form($codedom,'showdom','',1,$onchange));
Line 359  sub category_breadcrumbs { Line 412  sub category_breadcrumbs {
             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')) {
                 $catlinks .= $crumbsymbol;                  $catlinks .= $crumbsymbol;
             } else {  
                 $catlinks .= '</td>';  
             }              }
         }          }
     } 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 381  sub category_breadcrumbs { Line 432  sub category_breadcrumbs {
                     $catlinks .= '<option value="">'.&mt('De-select').'</option>';                      $catlinks .= '<option value="">'.&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).':'.$container.':'.$shallower;                          my $item = &escape($name).':'.&escape($container).':'.$shallower;
                         my $selected = '';                          my $selected = '';
                         if ($item eq $env{'form.currcat_'.$shallower}) {                          if ($item eq $env{'form.currcat_'.$shallower}) {
                             $selected = ' selected="selected"';                              $selected = ' selected="selected"';
Line 479  sub get_depth_values { Line 530  sub get_depth_values {
   
 sub additional_filters {  sub additional_filters {
     my ($codedom,$has_subcats) = @_;      my ($codedom,$has_subcats) = @_;
     my $output = '<table>';      my $is_dc = &user_is_dc($codedom);
     if (($env{'form.currcat_0'} ne 'instcode::0') &&       my $output = '<div class="LC_left_float">';
       if ($is_dc) {
           $output .= '<fieldset><legend>'.&mt('Options').'</legend>';
       }
       $output .= '<table><tr><td valign="top">';
       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;
         if ($env{'form.withsubcats'}) {          if ($env{'form.withsubcats'}) {
Line 496  sub additional_filters { Line 552  sub additional_filters {
         }          }
         my ($catname) = split(/:/,$env{'form.currcat_'.$counter});          my ($catname) = split(/:/,$env{'form.currcat_'.$counter});
         if ($catname ne '') {          if ($catname ne '') {
             $output .= '<tr><td><label>'.              $output .= '<span class="LC_nobreak"><label>'.
                        '<input type="checkbox" name="withsubcats" value="1" '.                         '<input type="checkbox" name="withsubcats" value="1" '.
                        $include_subcat_status.'/>'.                         $include_subcat_status.'/>'.
                        &mt('Include subcategories within "[_1]"',                         &mt('Include subcategories within "[_1]"',
                            &unescape($catname)).'</label></td></tr>';                             &unescape($catname)).'</label></span><br />';
         }          }
     }      }
     my $show_selfenroll_status;      my $show_selfenroll_status;
Line 509  sub additional_filters { Line 565  sub additional_filters {
     }      }
     my $selfenroll_text;      my $selfenroll_text;
     if ($env{'form.currcat_0'} eq 'communities::0') {      if ($env{'form.currcat_0'} eq 'communities::0') {
         $selfenroll_text = &mt('Only show communities which allow self-enrollment');          $selfenroll_text = &mt('Only show communities which currently allow self-enrollment (or will allow it in the future)');
     } else {      } else {
         $selfenroll_text = &mt('Only show courses which allow self-enrollment');          $selfenroll_text = &mt('Only show courses which currently allow self-enrollment (or will allow it in the future)');
     }      }
     $output .= '<tr><td>'.      $output .= '<span class="LC_nobreak">'.
                '<label><input type="checkbox" name="showselfenroll" value="1" '.                 '<label><input type="checkbox" name="showselfenroll" value="1" '.
                $show_selfenroll_status.'/>'.$selfenroll_text.                 $show_selfenroll_status.'/>'.$selfenroll_text.
                '</label></td></tr>';                 '</label></span><br />';
     if (&user_is_dc($codedom)) {      if ($is_dc) {
           my ($titlesref,$orderref) = &get_statustitles('filters');
         my $showdetails_status;          my $showdetails_status;
         if ($env{'form.showdetails'}) {          if ($env{'form.showdetails'}) {
             $showdetails_status = 'checked="checked" ';              $showdetails_status = 'checked="checked" ';
         }          }
         my $showhidden_status;          my $showhidden_status;
         if ($env{'form.showhidden'}) {          if ($env{'form.showhidden'}) {
              $showhidden_status = 'checked="checked" ';              $showhidden_status = 'checked="checked" ';
         }          }
           my @currstatuses = &Apache::loncommon::get_env_multiple('form.showcounts');
         my $dc_title = &Apache::lonnet::plaintext('dc');          my $dc_title = &Apache::lonnet::plaintext('dc');
         my ($details_text,$hidden_text);          my ($details_text,$hidden_text,$statusdisplay,$cellborder);
           my $wasactivedisplay = 'none';
           if ($env{'form.showdetails'}) {
               $statusdisplay = 'block';
               $cellborder = 'border-left: 1px solid;';
               if (grep(/^Previous$/,@currstatuses)) {
                   $wasactivedisplay = 'block';
               }
           } else {
               $statusdisplay = 'none';
               $cellborder = 'border-left: 0px';
           }
         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 ([_1] only)',$dc_title);              $details_text = &mt('Show full details for each community ([_1] only)',$dc_title);
             $hidden_text = &mt('Include communities set to be hidden from catalog ([_1] only)',$dc_title);              $hidden_text = &mt('Include communities set to be hidden from catalog ([_1] only)',$dc_title);
Line 535  sub additional_filters { Line 604  sub additional_filters {
             $details_text = &mt('Show full details for each course ([_1] only)',$dc_title);              $details_text = &mt('Show full details for each course ([_1] only)',$dc_title);
             $hidden_text = &mt('Include courses set to be hidden from catalog ([_1] only)',$dc_title);              $hidden_text = &mt('Include courses set to be hidden from catalog ([_1] only)',$dc_title);
         }          }
         $output .= '<tr><td>'."\n".          $output .= '<span class="LC_nobreak">'.
                    '<label><input type="checkbox" name="showdetails" value="1" '.  
                    $showdetails_status.'/>'.$details_text.  
                    '</label>'."\n".'</td></tr><tr><td>'.  
                    '<label><input type="checkbox" name="showhidden" value="1" '.                     '<label><input type="checkbox" name="showhidden" value="1" '.
                    $showhidden_status.'/>'.$hidden_text.                     $showhidden_status.'/>'.$hidden_text.
                    '</label>'."\n".'</td></tr>';                     '</label></span><br />'."\n".
                      '<span class="LC_nobreak">'.
                      '<label><input type="checkbox" name="showdetails" value="1" '.
                      $showdetails_status.'onclick="toggleStatuses();" />'.
                      $details_text.'</label></span></td>'."\n".
                      '<td id="statuscell" valign="top" style="'.$cellborder.'">'.
                      '<div id="statuschoice" style="display:'.$statusdisplay.'">';
           if (ref($orderref) eq 'ARRAY') {
               if (@{$orderref} > 0) {
                   foreach my $type (@{$orderref}) {
                       my $checked;
                       if (grep(/^\Q$type\E$/,@currstatuses)) {
                           $checked = ' checked="checked"';
                       }
                       my $title;
                       if (ref($titlesref) eq 'HASH') {
                           $title = $titlesref->{$type};
                       }
                       unless ($title) {
                           $title = &mt($type);
                       }
                       my $onclick;
                       if ($type eq 'Previous') {
                           $onclick = ' onclick="toggleWasActive();"'; 
                       }
                       $output .= '<span class="LC_nobreak">'.
                                  '<label><input type="checkbox" id="counts_'.$type.'"'.
                                  ' name="showcounts" value="'.$type.'"'.$checked.$onclick.
                                  ' />'.$title.'</label></span>';
                       if ($type eq 'Previous') {
                           my %milestonetext = &Apache::lonlocal::texthash (
                               accessend => 'immediately prior to default end access date',
                               enrollend => 'immediately prior to end date for auto-enrollment',
                               date      => 'immediately prior to specific date:',
                           );
                           my @statuses = &Apache::loncommon::get_env_multiple('form.showcounts');
                           $output .= '<span id="choosewasacctext">';
                           if ($checked) {
                               $output .= &get_wasactive_text();
                           }
                           $output .= '</span>'.
                                      '<div id="choosewasactive" style="display:'.$wasactivedisplay.'">'.
                                      '<table>';
                           my @milestones = ('accessend');
                           if (&Apache::lonnet::auto_run(undef,$codedom)) {
                               push(@milestones,'enrollend');
                           }
                           push(@milestones,'date');
                           foreach my $item (@milestones) {
                               my $checked;
                               if ($env{'form.state'} eq 'listing') {
                                   if ($env{'form.wasactive'} eq $item) {
                                       $checked = ' checked="checked"';
                                   }
                               } elsif ($item eq 'accessend') {
                                   $checked = ' checked="checked"';
                               }
                               $output .=
                                   '<tr><td width="10">&nbsp;</td><td>'.
                                   '<span class="LC_nobreak"><label>'.
                                   '<input type="radio" value="'.$item.'" name="wasactive"'.$checked.' />'.
                                   $milestonetext{$item}.'</label></span>';
                               if ($item eq 'date') {
                                   my $wasactiveon;
                                   if (grep(/^Previous$/,@currstatuses)) {
                                       $wasactiveon =
                                           &Apache::lonhtmlcommon::get_date_from_form('wasactiveon');
                                   } else {
                                       $wasactiveon = 'now';
                                   }
                                   $output .= ' '.
                                       &Apache::lonhtmlcommon::date_setter('coursecatalog',
                                                                           'wasactiveon',
                                                                           $wasactiveon,
                                                                           '','','',1,'',
                                                                           '','',1);
                               }
                               $output .= '</td></tr>';
                           }
                           $output .= '</table></div>';
                       }
                       $output .= '<br />';
                   }
               }
           }
           $output .= '</div></td>';
       } else {
           $output .= '</td>';  
     }      }
     $output .= '</table><br />';      $output .= '</tr></table></fieldset></div>'.
                  '<div style="clear:both;margin:0;"></div>';  
     return $output;      return $output;
 }  }
   
Line 560  sub user_is_dc { Line 714  sub user_is_dc {
     return;      return;
 }  }
   
   sub get_statustitles {
       my ($caller) = @_;
       my @status_order = ('Active','Future','Previous');
       my %status_title;
       if ($caller eq 'filters') {
           %status_title = &Apache::lonlocal::texthash(
                              Previous => 'Show count for past access',
                              Active => 'Show count for current student access',
                              Future => 'Show count for future student access',
                           );
           if ($env{'form.currcat_0'} eq 'communities::0') {
               $status_title{'Active'} = 'Show count for current member access';
               $status_title{'Future'} = 'Show count for future member access'; 
           }
       } else {    
           %status_title = &Apache::lonlocal::texthash(
                              Previous => 'Previous access',
                              Active => 'Current access',
                              Future => 'Future access',
                           );
       }
       return (\%status_title,\@status_order);
   }
   
   sub get_wasactive_text {
       my $wasacctext = ' -- ';
       if ($env{'form.currcat_0'} eq 'communities::0') {
           $wasacctext .= &mt('where member access status was current ...');
       } else {
           $wasacctext .= &mt('where student access status was current ...');
       }
       return $wasacctext;
   }
   
 sub search_official_courselist {  sub search_official_courselist {
     my ($domain,$numtitles) = @_;      my ($domain,$numtitles,$codetitles) = @_;
     my $instcode = &Apache::courseclassifier::instcode_search_str($domain,$numtitles);      my $instcode = &Apache::courseclassifier::instcode_search_str($domain,$numtitles,$codetitles);
     my $showhidden;      my $showhidden;
     if (&user_is_dc($domain)) {      if (&user_is_dc($domain)) {
         $showhidden = $env{'form.showhidden'};          $showhidden = $env{'form.showhidden'};
Line 619  sub search_courselist { Line 807  sub search_courselist {
 }  }
   
 sub print_course_listing {  sub print_course_listing {
     my ($domain,$numtitles,$trails,$allitems,$subcats) = @_;      my ($domain,$numtitles,$trails,$allitems,$subcats,$codetitles) = @_;
     my $output;      my $output;
     my %courses;      my %courses;
     my $knownuser = &user_is_known();      my $knownuser = &user_is_known();
Line 634  sub print_course_listing { Line 822  sub print_course_listing {
                                                  $env{'form.coursenum'},                                                   $env{'form.coursenum'},
                                                  undef,undef,'.',1);                                                   undef,undef,'.',1);
         if (keys(%courses) == 0) {          if (keys(%courses) == 0) {
             $output .= &mt('The courseID provided does not match a course in this domain.');              if ($env{'form.currcat_0'} eq 'communities::0') {
                   $output .= &mt('The courseID provided does not match a community in this domain.');
               } else { 
                   $output .= &mt('The courseID provided does not match a course in this domain.');
               }
             return $output;              return $output;
         }          }
     } else {      } else {
         if ($env{'form.currcat_0'} eq 'instcode::0') {          if ($env{'form.currcat_0'} eq 'instcode::0') {
             %courses = &search_official_courselist($domain,$numtitles);              %courses = &search_official_courselist($domain,$numtitles,$codetitles);
         } else {          } else {
             %courses = &search_courselist($domain,$subcats);              %courses = &search_courselist($domain,$subcats);
         }          }
         if (keys(%courses) == 0) {          if (keys(%courses) == 0) {
             if ($env{'form.currcat_0'} eq 'communities::0') {              if ($env{'form.currcat_0'} eq 'communities::0') {
                 $output = &mt('No communities match the criteria you selected.');                  $output =
                       '<p class="LC_info">'
                      .&mt('No communities match the criteria you selected.')
                      .'</p>';
             } else {              } else {
                 $output = &mt('No courses match the criteria you selected.');                  $output =
                       '<p class="LC_info">'
                      .&mt('No courses match the criteria you selected.')
                      .'</p>';
             }              }
             return $output;              return $output;
         }          }
Line 660  sub print_course_listing { Line 858  sub print_course_listing {
     my $now = time;      my $now = time;
     my %domconfig =      my %domconfig =
         &Apache::lonnet::get_dom('configuration',['usercreation'],$domain);          &Apache::lonnet::get_dom('configuration',['usercreation'],$domain);
     $output .= &construct_data_table($knownuser,\%courses,$details,undef,$now,\%domconfig,$trails,$allitems);      $output .= &construct_data_table($knownuser,$domain,\%courses,$details,undef,
                                        $now,\%domconfig,$trails,$allitems);
     $output .= "\n".'<form name="linklaunch" method="post" action="">'.      $output .= "\n".'<form name="linklaunch" method="post" action="">'.
                '<input type="hidden" name="backto" value="coursecatalog" />'.                 '<input type="hidden" name="backto" value="coursecatalog" />'.
                '<input type="hidden" name="courseid" value="" />'.                 '<input type="hidden" name="courseid" value="" />'.
Line 669  sub print_course_listing { Line 868  sub print_course_listing {
 }  }
   
 sub construct_data_table {  sub construct_data_table {
     my ($knownuser,$courses,$details,$usersections,$now,$domconfig,$trails,      my ($knownuser,$domain,$courses,$details,$usersections,$now,$domconfig,
         $allitems) = @_;          $trails,$allitems) = @_;
     my %sortname;      my %sortname;
     if (($details eq '') || ($env{'form.showdetails'})) {      if (($details eq '') || ($env{'form.showdetails'})) {
         $sortname{'Code'} = 'code';          $sortname{'Code'} = 'code';
         $sortname{'Categories'} = 'cats';          $sortname{'Categories'} = 'cats';
         $sortname{'Title'} = 'title';          $sortname{'Title'} = 'title';
         $sortname{'Owner(s)'} = 'owner';          $sortname{'Owner & Co-owner(s)'} = 'owner';
     }      }
     my $output = &Apache::loncommon::start_data_table().      my $output = &Apache::loncommon::start_data_table().
                  &Apache::loncommon::start_data_table_header_row();                   &Apache::loncommon::start_data_table_header_row();
Line 686  sub construct_data_table { Line 885  sub construct_data_table {
     } else {      } else {
         push(@coltitles,'Categories');          push(@coltitles,'Categories');
     }      }
     push(@coltitles,('Sections','Crosslisted','Title','Owner(s)'));      push(@coltitles,('Sections','Crosslisted','Title','Owner & Co-owner(s)'));
     if (ref($usersections) eq 'HASH') {      if (ref($usersections) eq 'HASH') {
        $coltitles[1] = 'Your Section';         $coltitles[1] = 'Your Section';
     }      }
Line 701  sub construct_data_table { Line 900  sub construct_data_table {
         }          }
         $output .= '</th>';          $output .= '</th>';
     }      }
       my (@fields,%fieldtitles,$wasactiveon);
     if ($knownuser) {      if ($knownuser) {
         if ($details) {          if ($details) {
             $output .=              if ($env{'form.currcat_0'} eq 'communities::0') {
               '<th>'.&mt('Default Access Dates for Students').'</th>'.                  $output .= '<th>'.&mt('Default Access Dates for Members').'</th>'.
               '<th>'.&mt('Student Counts').'</th>'.                             '<th>'.&mt('Member Counts').'</th>';
               '<th>'.&mt('Auto-enrollment of[_1]registered students','<br />').'</th>';              } else {
                   $output .=
                       '<th>'.&mt('Default Access Dates for Students').'</th>'.
                       '<th>'.&mt('Student Counts').'</th>'.
                       '<th>'.&mt('Auto-enrollment of[_1]registered students','<br />').'</th>';
               }
               my ($titlesref,$orderref) = &get_statustitles();
               my @statuses;
               if (&user_is_dc($domain)) {
                   @statuses = &Apache::loncommon::get_env_multiple('form.showcounts');
                   if (grep(/^Previous$/,@statuses)) {
                       if ($env{'form.wasactive'} eq 'date') { 
                           $wasactiveon = 
                               &Apache::lonhtmlcommon::get_date_from_form('wasactiveon');
                       } else {
                           $wasactiveon = $env{'form.wasactive'};
                       }
                   }
                   if (ref($orderref) eq 'ARRAY') {
                       foreach my $status (@{$orderref}) {
                           if (grep(/^\Q$status\E$/,@statuses)) {
                               push(@fields,$status); 
                           }
                       }
                   }
               } else {
                   @fields = ('Active','Future');
               }
               foreach my $status (@fields) {
                   my $title;
                   if (ref($titlesref) eq 'HASH') {
                       $title = $titlesref->{$status};
                   }
                   unless ($title) {
                       $title = &mt($status);
                   }
                   $fieldtitles{$status} = $title;
               }
         } else {          } else {
             $output .= '<th>'.&mt('Details').'</th>';              $output .= '<th>'.&mt('Details').'</th>';
         }          }
     }      }
     $output .= '<th>'.&mt('Self-enroll (if permitted)').'</th>';      $output .= '<th>'.&mt('Self-enroll (if permitted)').'</th>';
     &Apache::loncommon::end_data_table_header_row();      &Apache::loncommon::end_data_table_header_row();
     my %courseinfo = &build_courseinfo_hash($courses,$knownuser,$details,      my (%numbers,%creditsum);
                                             $usersections);      my ($showcredits,$defofficial,$defunofficial);
       my %domdefaults = &Apache::lonnet::get_domain_defaults($domain);
       unless ($env{'form.currcat_0'} eq 'communities::0') {
           if ($domdefaults{'officialcredits'} || $domdefaults{'unofficialcredits'}) {
               $showcredits = 1;
               $defofficial = $domdefaults{'officialcredits'};
               $defunofficial = $domdefaults{'unofficialcredits'}; 
           }
       }
       my %courseinfo = &build_courseinfo_hash($courses,$knownuser,$domain,$details,
                                               $usersections,\@fields,\%fieldtitles,
                                               $wasactiveon,\%numbers,\%creditsum,
                                               $showcredits,$defofficial,$defunofficial);
     my %Sortby;      my %Sortby;
     foreach my $course (sort(keys(%{$courses}))) {      foreach my $course (sort(keys(%{$courses}))) {
         if ($env{'form.sortby'} eq 'code') {          if ($env{'form.sortby'} eq 'code') {
Line 740  sub construct_data_table { Line 989  sub construct_data_table {
         @sorted_courses = sort { lc($a) cmp lc($b) } (keys(%Sortby));          @sorted_courses = sort { lc($a) cmp lc($b) } (keys(%Sortby));
     }      }
     my $count = 1;      my $count = 1;
       my $totalsec = 0;
     foreach my $item (@sorted_courses) {      foreach my $item (@sorted_courses) {
         foreach my $course (@{$Sortby{$item}}) {          foreach my $course (@{$Sortby{$item}}) {
             $output.=&Apache::loncommon::start_data_table_row();               $output.=&Apache::loncommon::start_data_table_row(); 
             $output.=&courseinfo_row($courseinfo{$course},$knownuser,$details,              $output.=&courseinfo_row($courseinfo{$course},$knownuser,$details,
                                      \$count,$now,$course,$trails,$allitems);                                       \$count,$now,$course,$trails,$allitems,\%numbers);
             $output.=&Apache::loncommon::end_data_table_row();              $output.=&Apache::loncommon::end_data_table_row();
         }          }
     }      }
       if (($knownuser) && ($count > 1) && $env{'form.showdetails'}) {
           if (&user_is_dc($domain)) {
               my %lt = &Apache::lonlocal::texthash (
                                                        'Active'   => 'Total current students',
                                                        'Future'   => 'Total future students',
                                                        'Previous' => 'Total previous students',
                                                        'courses'  => 'Total unique codes and courses without codes',
                                                        'sections' => 'Total sections',
                                                        'xlists'   => 'Total cross-listings',
                                                    );
               if ($showcredits) {
                   $lt{'cr_Active'} = &mt('Total current student credit hours');
                   $lt{'cr_Future'} = &mt('Total future student credit hours');
                   $lt{'cr_Previous'} = &mt('Total previous student credit hours');
               }
               if ($env{'form.currcat_0'} eq 'communities::0') {
                   $lt{'courses'} = &mt('Total communities');
                   $lt{'Active'} = &mt('Total current members'); 
                   $lt{'Future'} = &mt('Total future members');
                   $lt{'Previous'} = &mt('Total previous members');
               }
               my $colspan = 8;
               if ($showcredits) {
                   $colspan = 4;
               }
               $output .= '<tr class="LC_footer_row">'.
                          '<td colspan="2">&nbsp;</td>'.
                          '<td colspan="'.$colspan.'">'.
                          '<table border="0">';
               foreach my $item ('courses','sections','xlists') {
                   $output .= '<tr>'.
                              '<td>'.$lt{$item}.'</td><td>&nbsp;</td>'.
                              '<td align="right">'.$numbers{$item}.'</td>'.
                              '</tr>'."\n";
               }
               if (@fields > 0) { 
                   foreach my $status (@fields) {
                       $output .= '<tr>'.
                                  '<td>'.$lt{$status}.'</td><td>&nbsp;</td>'.
                                  '<td align="right">'.$numbers{$status}.'</td>'.
                                  '</tr>'."\n";
                   }
               }
               $output .= '</table></td>';
               if ($showcredits) {
                   $output .= '<td colspan="'.$colspan.'" valign="bottom"><table>';
                   foreach my $status (@fields) {
                       $output .= '<tr>'.
                                  '<td>'.$lt{'cr_'.$status}.'</td><td>&nbsp;</td>'.
                                  '<td align="right">'.$creditsum{$status}.'</td></tr>';
                   }
                   $output .= '</table></td></tr>';
               }
           }
       }
     $output .= &Apache::loncommon::end_data_table();      $output .= &Apache::loncommon::end_data_table();
     return $output;      return $output;
 }  }
   
 sub build_courseinfo_hash {  sub build_courseinfo_hash {
     my ($courses,$knownuser,$details,$usersections) = @_;      my ($courses,$knownuser,$domain,$details,$usersections,$fields,$fieldtitles,
           $wasactiveon,$numbers,$creditsum,$showcredits,$defofficial,$defunofficial) = @_;
     my %courseinfo;      my %courseinfo;
     my $now = time;      my $now = time;
       my $gettotals;
       if ((keys(%{$courses}) > 0) && (&user_is_dc($domain)) && ($details)) {
           $gettotals = 1;
       }
       my (%uniquecodes,$nocodes,$defcreds);
     foreach my $course (keys(%{$courses})) {      foreach my $course (keys(%{$courses})) {
         my $descr;          my $descr;
         if (ref($courses->{$course}) eq 'HASH') {          if (ref($courses->{$course}) eq 'HASH') {
Line 777  sub build_courseinfo_hash { Line 1088  sub build_courseinfo_hash {
             $selfenroll_end = $courses->{$course}{'selfenroll_end_date'};              $selfenroll_end = $courses->{$course}{'selfenroll_end_date'};
             $categories = $courses->{$course}{'categories'};              $categories = $courses->{$course}{'categories'};
             push(@owners,$singleowner);              push(@owners,$singleowner);
             if (ref($courses->{$course}{'co-owners'}) eq 'ARRAY') {              if ($courses->{$course}{'co-owners'} ne '') {
                 foreach my $item (@{$courses->{$course}{'co-owners'}}) {                  foreach my $item (split(/,/,$courses->{$course}{'co-owners'})) {
                     push(@owners,$item);                      push(@owners,$item);
                 }                  }
             }              }
         }          }
           if ($instcode ne '') {
               $uniquecodes{$instcode} = 1;
           } else {
               $nocodes ++;
           } 
         foreach my $owner (@owners) {          foreach my $owner (@owners) {
             my ($ownername,$ownerdom);               my ($ownername,$ownerdom); 
             if ($owner =~ /:/) {              if ($owner =~ /:/) {
Line 820  sub build_courseinfo_hash { Line 1136  sub build_courseinfo_hash {
         my @crosslistings;          my @crosslistings;
         my ($seclist,$numsec) =           my ($seclist,$numsec) = 
             &identify_sections($coursehash{'internal.sectionnums'});              &identify_sections($coursehash{'internal.sectionnums'});
         if (ref($usersections) eq 'HASH') {  
             if (ref($usersections->{$course}) eq 'ARRAY') {  
                 $seclist = join(', ',@{$usersections->{$course}});  
             }  
         }  
         $courseinfo{$course}{'seclist'} = $seclist;          $courseinfo{$course}{'seclist'} = $seclist;
         my ($xlist_items,$numxlist) =           my ($xlist_items,$numxlist) = 
             &identify_sections($coursehash{'internal.crosslistings'});              &identify_sections($coursehash{'internal.crosslistings'});
           if (ref($numbers) eq 'HASH') {
               $numbers->{'sections'} += $numsec; 
               $numbers->{'xlists'} += $numxlist;  
           }
         my $showsyllabus = 1; # default is to include a syllabus link          my $showsyllabus = 1; # default is to include a syllabus link
         if (defined($coursehash{'showsyllabus'})) {          if (defined($coursehash{'showsyllabus'})) {
             $showsyllabus = $coursehash{'showsyllabus'};              $showsyllabus = $coursehash{'showsyllabus'};
         }          }
         $courseinfo{$course}{'showsyllabus'} = $showsyllabus;          $courseinfo{$course}{'showsyllabus'} = $showsyllabus;
           if ($showcredits) {
               if ($coursehash{'internal.defaultcredits'}) {
                   $courseinfo{$course}{'defaultcredits'} = $coursehash{'internal.defaultcredits'};
               } elsif ($instcode ne '') {
                   $courseinfo{$course}{'defaultcredits'} = $defofficial;
               } else {
                   $courseinfo{$course}{'defaultcredits'} = $defunofficial;
               }
               $defcreds = $courseinfo{$course}{'defaultcredits'};
           }
         if (((defined($env{'form.coursenum'}) && ($cnum eq $env{'form.coursenum'}))) ||          if (((defined($env{'form.coursenum'}) && ($cnum eq $env{'form.coursenum'}))) ||
             ($knownuser && ($details == 1))) {              ($knownuser && ($details == 1))) {
             $courseinfo{$course}{'counts'} =  &count_students($cdom,$cnum,$numsec);              my $milestone;
             $courseinfo{$course}{'autoenrollment'} =              if ($wasactiveon eq 'accessend') {
                 &autoenroll_info(\%coursehash,$now,$seclist,$xlist_items,                  if ($coursehash{'default_enrollment_end_date'}) {
                                  $instcode,\@owners,$cdom,$cnum);                      $milestone = $coursehash{'default_enrollment_end_date'};
                   } else {
                       $milestone = time;
                   }
               } elsif ($wasactiveon eq 'enrollend') {
                   if ($coursehash{'internal.autoend'}) {
                       $milestone = $coursehash{'internal.autoend'};
                   } else {
                       $milestone = time;
                   }
               } else {
                   $milestone = $wasactiveon;
               }
               $courseinfo{$course}{'counts'} =  
                   &count_students($cdom,$cnum,$numsec,$fields,$fieldtitles,$gettotals,
                                   $numbers,$creditsum,$showcredits,$defcreds,$milestone);
               if ($instcode ne '') {
                   $courseinfo{$course}{'autoenrollment'} =
                       &autoenroll_info(\%coursehash,$now,$seclist,$xlist_items,
                                        $instcode,\@owners,$cdom,$cnum);
               }
             my $startaccess = '';              my $startaccess = '';
             my $endaccess = '';              my $endaccess = '';
             my $accessdates;              my $accessdates;
Line 892  sub build_courseinfo_hash { Line 1236  sub build_courseinfo_hash {
         }          }
         $courseinfo{$course}{'xlist'} = $xlist_items;          $courseinfo{$course}{'xlist'} = $xlist_items;
     }      }
       if (ref($numbers) eq 'HASH') {
           $numbers->{'courses'} = $nocodes + scalar(keys(%uniquecodes));
       }
     return %courseinfo;      return %courseinfo;
 }  }
   
 sub count_students {  sub count_students {
     my ($cdom,$cnum,$numsec) = @_;      my ($cdom,$cnum,$numsec,$fieldsref,$titlesref,$getcounts,$numbers,$creditsum,
           $showcredits,$defcreds,$wasactiveon) = @_;
       my $countslist = '<span class="LC_nobreak">'.
                        &mt('[quant,_1,section,sections,No sections]',$numsec).'</span>';
       my (@fields,%titles,$showexpired);
       if ((ref($fieldsref) eq 'ARRAY') && (ref($titlesref) eq 'HASH') &&
           (ref($numbers) eq 'HASH')) {
           @fields = @{$fieldsref};
           %titles = %{$titlesref};
           if (grep(/^Previous$/,@fields)) {
               $showexpired = 1;
           }
       } else {
           return;
       }
     my $classlist = &Apache::loncoursedata::get_classlist($cdom,$cnum);      my $classlist = &Apache::loncoursedata::get_classlist($cdom,$cnum);
     my %student_count = (      my (%student_count,%credit_count);
                            Active => 0,      %student_count = (
                            Future => 0,                             Active   => 0,
                            Expired => 0,                             Future   => 0,
                        );                             Previous => 0,
                        );
       if ($showcredits) {
           %credit_count = (
                             Active   => 0,
                             Future   => 0,
                             Previous => 0,
                           );
       }
     my %idx;      my %idx;
     $idx{'status'} = &Apache::loncoursedata::CL_STATUS();      $idx{'status'} = &Apache::loncoursedata::CL_STATUS();
     my %status_title = &Apache::lonlocal::texthash(      $idx{'end'}    = &Apache::loncoursedata::CL_END();
                            Expired => 'Previous access',      $idx{'credits'} = &Apache::loncoursedata::CL_CREDITS();
                            Active => 'Current access',  
                            Future => 'Future access',  
                        );  
   
     while (my ($student,$data) = each(%$classlist)) {      while (my ($student,$data) = each(%$classlist)) {
         $student_count{$data->[$idx{'status'}]} ++;          my $status = $data->[$idx{'status'}];
           my $credits = $data->[$idx{'credits'}];
           if ($credits eq '') {
               $credits = $defcreds;  
           }
           if ($status eq 'Expired') {
               if (($showexpired) &&
                   ($data->[$idx{'end'}] >= $wasactiveon)) {
                   $student_count{'Previous'} ++;
                   if ($showcredits) {
                       $credit_count{'Previous'} += $credits; 
                   }
               }
           } else {
               $student_count{$status} ++;
               if ($showcredits) {
                   $credit_count{$status} += $credits;
               }
           }
     }      }
       if (@fields) {
     my $countslist = &mt('[quant,_1,section:,sections:,No sections]',$numsec).'<br />';          $countslist .= ':<br />';
     foreach my $status ('Active','Future') {          foreach my $status (@fields) {
         $countslist .= '<span class="LC_nobreak">'.$status_title{$status}.': '.              $countslist .= '<span class="LC_nobreak">'.$titles{$status}.': '.
                        $student_count{$status}.'</span><br />';                             $student_count{$status}.'</span><br />';
               $numbers->{$status} += $student_count{$status};
               if ($showcredits) {
                   $creditsum->{$status} += $credit_count{$status};
               }
           }
     }      }
     return $countslist;      return $countslist;
 }  }
   
 sub courseinfo_row {  sub courseinfo_row {
     my ($info,$knownuser,$details,$countref,$now,$course,$trails,$allitems) = @_;      my ($info,$knownuser,$details,$countref,$now,$course,$trails,$allitems,$numbers) = @_;
     my ($cdom,$cnum,$title,$ownerlast,$code,$owner,$seclist,$xlist_items,      my ($cdom,$cnum,$title,$ownerlast,$code,$owner,$seclist,$xlist_items,
         $accessdates,$showsyllabus,$counts,$autoenrollment,$output,$categories);          $accessdates,$showsyllabus,$counts,$autoenrollment,$output,$categories);
     if (ref($info) eq 'HASH') {      if (ref($info) eq 'HASH') {
Line 976  sub courseinfo_row { Line 1364  sub courseinfo_row {
     if ($knownuser) {      if ($knownuser) {
         if ($details) {          if ($details) {
             $output .=              $output .=
                '<td>'.$accessdates.'</td>'.                   '<td>'.$accessdates.'</td>'.
                '<td>'.$counts.'</td>'.                  '<td>'.$counts.'</td>';
                '<td>'.$autoenrollment.'</td>';              unless ($env{'form.currcat_0'} eq 'communities::0') {
                   $output .= '<td>'.$autoenrollment.'</td>';
               }
         } else {          } else {
             $output .= "<td><a href=\"javascript:setCourseId('$cnum')\">".&mt('Show more details').'</a></td>';              $output .= "<td><a href=\"javascript:setCourseId('$cnum')\">".&mt('Show more details').'</a></td>';
         }          }
Line 991  sub courseinfo_row { Line 1381  sub courseinfo_row {
             if (($info->{'selfenroll_start'} > 0) && ($info->{'selfenroll_start'} > $now)) {              if (($info->{'selfenroll_start'} > 0) && ($info->{'selfenroll_start'} > $now)) {
                 $output .= '<td>'.&mt('Starts: [_1]','<span class="LC_cusr_emph">'.$showstart.'</span>').'<br />'.&mt('Ends: [_1]','<span class="LC_cusr_emph">'.$showend.'</span>').'</td>';                  $output .= '<td>'.&mt('Starts: [_1]','<span class="LC_cusr_emph">'.$showstart.'</span>').'<br />'.&mt('Ends: [_1]','<span class="LC_cusr_emph">'.$showend.'</span>').'</td>';
             } else {               } else { 
                 $output .= '<td><a href="javascript:ToSelfenroll('."'$course'".')">'.&mt('Enroll in course').'</a></td>';                  $output .= '<td><a href="javascript:ToSelfenroll('."'$course'".')">'.&mt('Enroll in course').'</a><br />';
                   if ($info->{'selfenroll_end'} == 0) {
                       $output .= &mt('Available permanently');
                   } elsif ($info->{'selfenroll_end'} > $now) {
                       $output .= &mt('Self-enrollment ends: [_1]','<span class="LC_cusr_emph">'.$showend.'</span>');
                   }
                   $output .= '</td>';
             }              }
             $selfenroll = 1;              $selfenroll = 1;
         }          }

Removed from v.1.53.4.4  
changed lines
  Added in v.1.75


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