Diff for /loncom/interface/coursecatalog.pm between versions 1.35 and 1.53.4.3

version 1.35, 2008/07/06 17:59:25 version 1.53.4.3, 2010/01/02 23:32:06
Line 53  sub handler { Line 53  sub handler {
     }      }
     &Apache::lonacc::get_posted_cgi($r);      &Apache::lonacc::get_posted_cgi($r);
     &Apache::lonlocal::get_language_handle($r);      &Apache::lonlocal::get_language_handle($r);
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['sortby']);      &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},
                                               ['sortby','showdom']);
   
     my $codedom = &Apache::lonnet::default_login_domain();      my $codedom = &Apache::lonnet::default_login_domain();
   
Line 74  sub handler { Line 75  sub handler {
   
     my %domconfig =      my %domconfig =
         &Apache::lonnet::get_dom('configuration',['coursecategories'],$codedom);          &Apache::lonnet::get_dom('configuration',['coursecategories'],$codedom);
     my (@cats,@trails,%allitems,%idx,@jsarray,$cathash);      my (@cats,@trails,%allitems,%idx,@jsarray,%subcathash,$cathash);
     if (ref($domconfig{'coursecategories'}) eq 'HASH') {      if (ref($domconfig{'coursecategories'}) eq 'HASH') {
         $cathash = $domconfig{'coursecategories'}{'cats'};          $cathash = $domconfig{'coursecategories'}{'cats'};
     } else {      } else {
         $cathash = {};          $cathash = {};
     }      }
       my $subcats;
       if ($env{'form.withsubcats'}) {
           $subcats = \%subcathash;
       }
     &Apache::loncommon::extract_categories($cathash,\@cats,\@trails,\%allitems,      &Apache::loncommon::extract_categories($cathash,\@cats,\@trails,\%allitems,
                                            \%idx,\@jsarray);                                             \%idx,\@jsarray,$subcats);
     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);
     } else {      } else {
         my $catlinks = &category_breadcrumbs($codedom,@cats);          my ($catlinks,$has_subcats,$selitem) = &category_breadcrumbs($codedom,@cats);
         my $catjs = <<"ENDSCRIPT";          my $catjs = <<"ENDSCRIPT";
   
 function setCatDepth(depth) {  function setCatDepth(depth) {
     document.coursecats.catalog_maxdepth.value = depth;      document.coursecats.catalog_maxdepth.value = depth;
       if (depth == '') {
           document.coursecats.currcat_0.value = '';
       }
     document.coursecats.submit();      document.coursecats.submit();
     return;      return;
 }  }
   
 ENDSCRIPT  
         if ($env{'form.state'} eq 'listing') {  
             $catjs .= qq|  
 function changeSort(caller) {  function changeSort(caller) {
     document.$formname.sortby.value = caller;      document.$formname.sortby.value = caller;
     document.$formname.submit();      document.$formname.submit();
 }  }
   
 function setCourseId(caller) {  function setCourseId(caller) {
     document.$formname.coursenum.value = caller;      document.$formname.coursenum.value = caller;
     document.$formname.submit();      document.$formname.submit();
 }\n|;  }
         }  
   ENDSCRIPT
           $catjs .= &courselink_javascript(); 
         my $numtitles;          my $numtitles;
         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,
Line 115  function setCourseId(caller) { Line 123  function setCourseId(caller) {
             }              }
         } else {          } else {
             my (%add_entries);              my (%add_entries);
               my ($currdepth,$deeper) = &get_depth_values();
               if ($selitem) {
                   my $alert = &mt('Choose a subcategory to display');
                   if (!$deeper) {
                       $alert = &mt('Choose a category to display');
                   }
                   $catjs .= <<ENDJS;
   function check_selected() {
       if (document.coursecats.$selitem.options[document.coursecats.$selitem.selectedIndex].value == "") {
           alert('$alert');
           return false;
       }
   }
   ENDJS
               }
             $catjs = '<script type="text/javascript">'."\n".$catjs."\n".'</script>';              $catjs = '<script type="text/javascript">'."\n".$catjs."\n".'</script>';
             &cat_header($r,$codedom,$catjs,\%add_entries,$catlinks);              &cat_header($r,$codedom,$catjs,\%add_entries,$catlinks);
             if ($env{'form.currcat_0'} ne '') {              if ($env{'form.currcat_0'} ne '') {
                 $r->print('<form name="'.$formname.                  $r->print('<form name="'.$formname.
                           '" method="post" action="/adm/coursecatalog">'.                            '" method="post" action="/adm/coursecatalog">'.
                           &additional_filters($codedom)."\n");                            &additional_filters($codedom,$has_subcats)."\n");
                 my ($currdepth,$deeper) = &get_depth_values();  
                 $r->print('<input type="hidden" name="catalog_maxdepth" value="'.                  $r->print('<input type="hidden" name="catalog_maxdepth" value="'.
                           $deeper.'" />'."\n");                            $deeper.'" />'."\n");
                 for (my $i=0; $i<$deeper; $i++) {                  for (my $i=0; $i<$deeper; $i++) {
                     $r->print('<input type="hidden" name="currcat_'.$i.'" value="'.$env{'form.currcat_'.$i}.'" />'."\n");                      $r->print('<input type="hidden" name="currcat_'.$i.'" value="'.$env{'form.currcat_'.$i}.'" />'."\n");
                 }                  }
                   my $display_button;
                   if ($env{'form.currcat_0'} eq 'communities::0') {
                       $display_button = &mt('Display communities');
                   } else {
                       $display_button = &mt('Display courses');
                   }
                 $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="showdom" value="'.                            '<input type="hidden" name="showdom" value="'.
                           $env{'form.showdom'}.'" />'.                            $env{'form.showdom'}.'" />'.
                           '<input type="submit" name="catalogfilter" value="'.                            '<input type="submit" name="catalogfilter" value="'.
                           &mt('Display courses').'" /></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));                  $r->print(&print_course_listing($codedom,undef,\@trails,\%allitems,$subcats));
             }              }
         }          }
     }      }
Line 149  sub course_details { Line 177  sub course_details {
     my $output;      my $output;
     my %add_entries = (topmargin    => "0",      my %add_entries = (topmargin    => "0",
                        marginheight => "0",);                         marginheight => "0",);
       my $js = '<script type="text/javascript">'."\n".
                &courselink_javascript().'</script>'."\n";
     my $start_page =      my $start_page =
         &Apache::loncommon::start_page('Course Catalog','',          &Apache::loncommon::start_page('Course/Community Catalog',$js,
                                            {                                             {
                                              'add_entries' => \%add_entries,                                               'add_entries' => \%add_entries,
                                              'no_inline_link'   => 1,});                                               'no_inline_link'   => 1,});
Line 158  sub course_details { Line 188  sub course_details {
     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=>"Select courses"});                    text=>"Course/Community Catalog"});
     }      }
     &Apache::lonhtmlcommon::add_breadcrumb      &Apache::lonhtmlcommon::add_breadcrumb
              ({href=>"javascript:document.$formname.submit()",               ({href=>"javascript:document.$formname.submit()",
               text=>"Course listing"},                text=>"Course listing"},
              {text=>"Course details"});               {text=>"Course details"});
     $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course Details'));      $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));
     $r->print('<br />'.&mt('Detailed course information:').'<br /><br />'.      $r->print('<br />'.&mt('Detailed course information:').'<br /><br />'.
               '<form name="'.$formname.'" method="post">'.  
               &print_course_listing($codedom,undef,$trails,$allitems).                &print_course_listing($codedom,undef,$trails,$allitems).
               '<br /><br />');                '<br /><br />');
     $r->print('<a href = "javascript:document.coursecatalog.submit()">'.      $r->print('<form name="'.$formname.'" method="post" action="/adm/coursecatalog">'.
                 '<a href = "javascript:document.coursecatalog.submit()">'.
               &mt('Back to course listing').'</a>'.                &mt('Back to course listing').'</a>'.
               '<input type="hidden" name="sortby" value="'.                &Apache::lonhtmlcommon::echo_form_input(['coursenum','catalogfilter',
               $env{'form.sortby'}.'" />'.                                                         'showdetails','courseid']).'</form>');
               '<input type="hidden" name="state" value="listing" /></form>');      return;
   }
   
   sub courselink_javascript {
       return <<"END";
   
   function ToSyllabus(cdom,cnum) {
       if (cdom == '' || cdom == null) {
           return;
       }
       if (cnum == '' || cnum == null) {
           return;
       }
       document.linklaunch.action = "/public/"+cdom+"/"+cnum+"/syllabus";
       document.linklaunch.submit();
   }
   
   function ToSelfenroll(courseid) {
       if (courseid == '') {
           return;
       }
       document.linklaunch.action = "/adm/selfenroll";
       document.linklaunch.courseid.value = courseid;
       document.linklaunch.submit();
   }
   
   END
 }  }
   
 sub instcode_course_selector {  sub instcode_course_selector {
Line 183  sub instcode_course_selector { Line 239  sub instcode_course_selector {
     my @codetitles = ();      my @codetitles = ();
     my %cat_titles = ();      my %cat_titles = ();
     my %cat_order = ();      my %cat_order = ();
     my %idlist = ();  
     my %idnums = ();  
     my %idlist_titles = ();  
     my %by_year;  
     my %by_sem;  
     my %by_dept;  
     my %cat_items;      my %cat_items;
     my $caller = 'global';      my $caller = 'global';
     my $format_reply;      my $format_reply;
     my $totcodes = 0;  
     my $jscript = '';  
     my ($numtitles,$lasttitle);  
     my %add_entries = (topmargin    => "0",      my %add_entries = (topmargin    => "0",
                        marginheight => "0",);                         marginheight => "0",);
     my $js;      my ($jscript,$totcodes,$numtitles,$lasttitle) = 
     $totcodes = &Apache::courseclassifier::retrieve_instcodes(\%coursecodes,$codedom);          &Apache::courseclassifier::instcode_selectors_data($codedom,$formname,
     if ($totcodes > 0) {                             \%cat_items,\@codetitles,\%cat_titles,\%cat_order);
         $format_reply = &Apache::lonnet::auto_instcode_format($caller,$codedom,\%coursecodes,\%codes,\@codetitles,\%cat_titles,\%cat_order);      my $js = '<script type"text/javascript">'."\n$jscript\n$catjs\n".
         if ($format_reply eq 'ok') {  
             my $numtypes = @codetitles;  
             &Apache::courseclassifier::build_code_selections(\%codes,\@codetitles,\%cat_titles,\%cat_order,\%idlist,\%idnums,\%idlist_titles);  
             my ($scripttext,$longtitles) = &Apache::courseclassifier::javascript_definitions(\@codetitles,\%idlist,\%idlist_titles,\%idnums,\%cat_titles);  
             my $longtitles_str = join('","',@{$longtitles});  
             my $allidlist = $idlist{$codetitles[0]};  
             $numtitles = @codetitles;  
             $lasttitle = $numtitles;  
             if ($numtitles > 4) {  
                 $lasttitle = 4;  
             }  
             if ($numtitles == 0) {  
                 if (!defined($env{'form.state'})) {  
                     $env{'form.state'} = 'listing';  
                 }  
             } else {  
                 my @data = ('top');  
                 for (my $k=0; $k<$lasttitle; $k++) {  
                     my $cat = $codetitles[$k];  
                     my $level = 1;  
                     $level = &recurse_options($codetitles[$k],$idlist{$codetitles[$k]},$level,$cat,\%cat_items,\@data,\%by_year,\%by_sem,\%by_dept);  
                 }  
                 $scripttext .= &build_javascript(\%by_year,\%by_sem,\%by_dept,\%cat_order,\@codetitles);  
                 $jscript .= &javascript_select_filler($formname,$scripttext,\@codetitles,$longtitles_str,$allidlist);  
                 if ($env{'form.state'} eq 'listing') {  
                     $jscript .= '  
 function setElements() {  
 ';  
                     for (my $i=0; $i<@codetitles-1; $i++) {  
                         if ($env{'form.'.$codetitles[$i]} != -1) {  
                             $jscript .= '  
     for (var j=0; j<document.'.$formname.'.'.$codetitles[$i].'.length; j++) {  
         if (document.'.$formname.'.'.$codetitles[$i].'[j].value == "'.$env{'form.'.$codetitles[$i]}.'") {  
             document.'.$formname.'.'.$codetitles[$i].'.selectedIndex = j;  
         }  
     }  
 ';  
                         }  
                     }  
                     $jscript .= '   courseSet()'."\n";  
                     if ($env{'form.'.$codetitles[-1]} != -1) {  
                         $jscript .= '  
     for (var j=0; j<document.'.$formname.'.'.$codetitles[-1].'.length; j++) {  
         if (document.'.$formname.'.'.$codetitles[-1].'[j].value == "'.$env{'form.'.$codetitles[-1]}.'") {  
             document.'.$formname.'.'.$codetitles[-1].'.selectedIndex = j;  
         }  
     }  
 ';  
                     }  
                     $jscript .= '}';  
                 }  
             }  
         }  
         $js = '<script type"text/javascript">'."\n$jscript\n$catjs\n".  
               '</script>';                '</script>';
       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()';
         }          }
Line 267  function setElements() { Line 261  function setElements() {
                   '<input type="hidden" name="currcat_0" value="instcode::0" />'.                    '<input type="hidden" name="currcat_0" value="instcode::0" />'.
                   &additional_filters($codedom));                    &additional_filters($codedom));
         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 />'.
             $r->print('<table><tr>');                        &Apache::courseclassifier::build_instcode_selectors($numtitles,
             for (my $k=0; $k<$lasttitle-1; $k++) {                         $lasttitle,\%cat_items,\@codetitles,\%cat_titles,\%cat_order));
                 my (@items,@unsorted);  
                 if (ref($cat_items{$codetitles[$k]}) eq 'ARRAY') {  
                     @unsorted = @{$cat_items{$codetitles[$k]}};  
                 }  
                 &Apache::courseclassifier::sort_cats($k,\%cat_order,\@codetitles,\@unsorted,\@items);  
                 my @longitems;  
                 if (defined($cat_titles{$codetitles[$k]})) {  
                     foreach my $item (@items) {  
                         push(@longitems,$cat_titles{$codetitles[$k]}{$item});  
                     }  
                 } else {  
                     @longitems = @items;  
                 }  
                 $r->print('<td align="center">'.$codetitles[$k].'<br />'."\n".  
                           '<select name="'.$codetitles[$k].'" onChange="courseSet()"');  
                 $r->print('>'."\n".'<option value="0" />All'."\n");  
                 for (my $i=0; $i<@items; $i++) {  
                     if ($longitems[$i] eq '') {  
                         $longitems[$i] = $items[$i];  
                     }  
                     $r->print(' <option value="'.$items[$i].'">'.$longitems[$i].'</option>');  
                 }  
                 $r->print('</select></td>');  
             }  
             $r->print('<td align="center">'.$codetitles[$lasttitle-1].'<br />'."\n".  
                       '<select name="'.$codetitles[$lasttitle-1].'">'."\n".  
                       '<option value="0">All'."\n".  
                       '</option>'."\n".'</select>'."\n".  
                  '</td></tr></table>'."\n");  
             if ($numtitles > 4) {  
                 $r->print('<br /><br />'.$codetitles[$numtitles-1].'<br />'."\n".  
                 '<input type="text" name="'.$codetitles[$numtitles-1].'" /><br />'."\n");  
             }  
             $r->print('<br />');  
         }          }
         $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".
Line 312  function setElements() { Line 272  function setElements() {
                   '<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.
                   '" /></form>');                    '" /></form><br /><br />');
         if (($numtitles > 0) && ($env{'form.state'} eq 'listing')) {  
             $r->print('<br />');  
         }  
     } else {      } else {
           $js = '<script type"text/javascript">'."\n$catjs\n".'</script>';
         &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'};
         $r->print('<form name="'.$formname.'" method="post" action="/adm/coursecatalog">'.          $r->print('<form name="'.$formname.'" method="post" action="/adm/coursecatalog">'.
Line 331  function setElements() { Line 289  function setElements() {
 sub cat_header {  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 Catalog',$js,          &Apache::loncommon::start_page('Other',$js,
                                        {                                         {
                                          'add_entries' => $add_entries,                                           'add_entries' => $add_entries,
                                          'no_inline_link'   => 1,});                                           'no_inline_link'   => 1,});
Line 340  sub cat_header { Line 298  sub cat_header {
         if ($numtitles > 0) {          if ($numtitles > 0) {
             &Apache::lonhtmlcommon::add_breadcrumb              &Apache::lonhtmlcommon::add_breadcrumb
                 ({href=>"/adm/coursecatalog",                  ({href=>"/adm/coursecatalog",
                   text=>"Select courses"},                    text=>"Course/Community Catalog"},
                  {text=>"Course listing"});                   {text=>"Course listing"});
         } else {          } else {
             &Apache::lonhtmlcommon::add_breadcrumb              &Apache::lonhtmlcommon::add_breadcrumb
             ({text=>"Course listing"});              ({text=>"Course listing"});
         }          }
         $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course Listing'));  
     } else {      } else {
         &Apache::lonhtmlcommon::add_breadcrumb          &Apache::lonhtmlcommon::add_breadcrumb
         ({href=>"/adm/coursecatalog",          ({href=>"/adm/coursecatalog",
           text=>"Select courses"});            text=>"Course/Community Catalog"});
         $r->print(&Apache::lonhtmlcommon::breadcrumbs('Select courses'));      }
       $r->print(&Apache::lonhtmlcommon::breadcrumbs('Course/Community Catalog'));
       my $onchange;
       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).                &Apache::loncommon::select_dom_form($codedom,'showdom','',1,$onchange));
       '&nbsp;<input type="submit" name="godom" value="'.&mt('Change').'" /></td></tr></table></form>'.      if (!$onchange) {
       '<form name="coursecats" method="post" action="/adm/coursecatalog">'.     $r->print('&nbsp;<input type="submit" name="godom" value="'.&mt('Change').'" />');
       }
       $r->print('</td></tr></table></form>'.
         '<form name="coursecats" method="post" action="/adm/coursecatalog"'.
                 ' onsubmit="return check_selected();">'.
               '<table border="0"><tr>'.$catlinks.'</tr></table></form>');                '<table border="0"><tr>'.$catlinks.'</tr></table></form>');
     return;      return;
 }  }
   
 sub category_breadcrumbs {  sub category_breadcrumbs {
     my ($dom,@cats) = @_;      my ($dom,@cats) = @_;
       my $crumbsymbol = ' &#x25b6; ';
     my ($currdepth,$deeper) = &get_depth_values();      my ($currdepth,$deeper) = &get_depth_values();
     my $currcat_str = '<input type="hidden" name="catalog_maxdepth" value="'.$deeper.'" /><input type="hidden" name="showdom" value="'.$dom.'" />';      my $currcat_str = 
     my $catlinks = '<td valign="top"><b>'.&mt('Catalog:').'</b></td><td><table><tr>';          '<input type="hidden" name="catalog_maxdepth" value="'.$deeper.'" />'.
     for (my $i=0; $i<$deeper; $i++) {          '<input type="hidden" name="showdom" value="'.$dom.'" />';
         $currcat_str .= '<input type="hidden" name="currcat_'.$i.'" value="'.$env{'form.currcat_'.$i}.'" />';      my $catlinks = '<td valign="top"><b>'.&mt('Catalog:').'</b></td><td><table><tr><td>';
         my ($cattitle,$shallower);      my $has_subcats;
         if ($i == 0) {      my $selitem;
             $cattitle = &mt('Main Categories');      if (ref($cats[0]) eq 'ARRAY') {
         } else {          if (@{$cats[0]} == 0) {
             $shallower = $i-1;              $catlinks .= &mt('No categories defined in this domain'); 
             my ($cat,$container,$depth) = map { &unescape($_); } split(/:/,$env{'form.currcat_'.$shallower});          } elsif (@{$cats[0]} == 1) {
             $cattitle = $cat;              if ($cats[0][0] eq 'instcode') {
         }                  $catlinks .= &mt('Official courses (with institutional codes)');
         $catlinks .= '<td valign="top"><a href="javascript:setCatDepth('."'$shallower'".')">'.$cattitle.'</a>-&gt;</td>';  
     }  
     if ($deeper == 0) {  
         $catlinks .= '<td>'.&mt('Main Categories').':&nbsp;';  
         if (ref($cats[0]) eq 'ARRAY') {  
             if ((@{$cats[0]} == 1) && ($cats[0][0] eq 'instcode')) {  
                 $catlinks .= &mt('Official courses (with institutional codes)').  
                              '<input type="hidden" name="currcat_0" value="instcode::0" />';  
                 $env{'form.currcat_0'} = 'instcode::0';                  $env{'form.currcat_0'} = 'instcode::0';
               } elsif ($cats[0][0] eq 'communities') {
                   $catlinks .= &mt('Communities');
                   $env{'form.currcat_0'} = 'communities::0';
             } else {              } else {
                 $catlinks .= '<select name="currcat_0">'."\n";                  my $name = $cats[0][0];
                 if (@{$cats[0]} > 1) {                  my $item = &escape($name).'::0';
                     my $selstr;                  $catlinks .= $name;
                     if ($env{'form.currcat_0'} eq '') {                  $env{'form.currcat_0'} = $item;
                         $selstr = ' selected="selected" ';  
                     }  
                     $catlinks .= '<option value=""'.$selstr.'>'.&mt('Select').'</option>'."\n";  
                 }  
                 for (my $i=0; $i<@{$cats[0]}; $i++) {  
                     my $name = $cats[0][$i];  
                     my $item = &escape($name).'::0';  
                     my $selstr;  
                     if ($env{'form.currcat_'.$i} eq $item) {  
                         $selstr = ' selected="selected" ';  
                     }  
                     $catlinks .= '<option value="'.$item.'"'.$selstr.'>';  
                     if ($name eq 'instcode') {  
                         $catlinks .= &mt('Official courses (with institutional codes)');  
                     } else {  
                         $catlinks .= $name;  
                     }  
                     $catlinks .= '</option>'."\n";  
                 }  
                 $catlinks .= '</select>'."\n".  
                              '&nbsp;<input type="submit" name="gocats" value="'.&mt('Change').'" />';  
             }              }
               $currcat_str .= '<input type="hidden" name="currcat_0" value="'.$env{'form.currcat_0'}.'" />';
         } else {          } else {
             $catlinks .= &mt('Official courses (with institutional codes)').              $catlinks .= &main_category_selector(@cats);
                          '<input type="hidden" name="currcat_0" value="instcode::0" />';              if (($env{'form.currcat_0'} ne '') && 
             $env{'form.currcat_0'} = 'instcode::0';                  ($env{'form.currcat_0'} ne 'instcode::0')) {
                   $catlinks .= $crumbsymbol;
               } else {
                   $catlinks .= '</td>';
               }
         }          }
     } else {      } else {
           $catlinks .= &mt('Official courses (with institutional codes)');
                        $env{'form.currcat_0'} = 'instcode::0';
           $currcat_str .= '<input type="hidden" name="currcat_0" value="'.$env{'form.currcat_0'}.'" />';
       }
       if ($deeper) {
           for (my $i=1; $i<=$deeper; $i++) {
               my $shallower = $i-1;
               next if ($shallower == 0);
               my ($cat,$container,$depth) = map { &unescape($_); } split(/:/,$env{'form.currcat_'.$shallower});
               if ($cat ne '') {
                   $catlinks .= '<td valign="top">'.
                                '<select name="currcat_'.$shallower.'" onchange="'.
                                'setCatDepth('."'$shallower'".');this.form.submit();">';
                   if (ref($cats[$shallower]{$container}) eq 'ARRAY') {
                       $catlinks .= '<option value="">'.&mt('De-select').'</option>';
                       for (my $j=0; $j<@{$cats[$shallower]{$container}}; $j++) {
                           my $name = $cats[$shallower]{$container}[$j];
                           my $item = &escape($name).':'.$container.':'.$shallower;
                           my $selected = '';
                           if ($item eq $env{'form.currcat_'.$shallower}) {
                               $selected = ' selected="selected"';
                           }
                           $catlinks .= 
                              '<option value="'.$item.'"'.$selected.'>'.$name.'</option>';
                       }
                   }
                   $catlinks .= '</select>';
               }
               unless ($i == $deeper) {
                   $catlinks .= $crumbsymbol;
               } 
           }
         my ($cat,$container,$depth);          my ($cat,$container,$depth);
         if ($env{'form.currcat_'.$currdepth} eq '') {          if ($env{'form.currcat_'.$currdepth} eq '') {
             my $shallower = $currdepth - 1;              my $shallower = $currdepth - 1;
Line 426  sub category_breadcrumbs { Line 403  sub category_breadcrumbs {
         } else {          } else {
             ($cat,$container,$depth) = map { &unescape($_); } split(/:/,$env{'form.currcat_'.$currdepth});              ($cat,$container,$depth) = map { &unescape($_); } split(/:/,$env{'form.currcat_'.$currdepth});
         }          }
         my $deeper = $depth +1;          my $deeperlevel = $depth +1;
         my $currcat = $cat;          if (ref($cats[$deeperlevel]{$cat}) eq 'ARRAY') {
         if ($cat eq 'instcode') {              $has_subcats = 1;
             $currcat = &mt('Official courses (with institutional codes)');              my $buttontext = &mt('Show subcategories');
         }              my $selitem = 'currcat_'.$deeperlevel;
         $catlinks .= '<td>'.$currcat;              $catlinks .= '&nbsp;<select name="'.$selitem.'" onchange="this.form.submit()">';
         if (ref($cats[$deeper]{$cat}) eq 'ARRAY') {              if (@{$cats[$deeperlevel]{$cat}}) {
             $catlinks .= ':&nbsp;<select name="currcat_'.$deeper.'">'.                  $catlinks .= '<option value="" selected="selected">'.
                          '<option value="" selected="selected">'.&mt('Select').'</option>';                               &mt('Subcategory ...').'</option>';
             for (my $k=0; $k<@{$cats[$deeper]{$cat}}; $k++) {              }
                 my $name = $cats[$deeper]{$cat}[$k];              for (my $k=0; $k<@{$cats[$deeperlevel]{$cat}}; $k++) {
                 my $item = &escape($name).':'.&escape($cat).':'.$deeper;                  my $name = $cats[$deeperlevel]{$cat}[$k];
                   my $item = &escape($name).':'.&escape($cat).':'.$deeperlevel;
                 $catlinks .= '<option value="'.$item.'">'.$name.'</option>'."\n";                  $catlinks .= '<option value="'.$item.'">'.$name.'</option>'."\n";
             }              }
             $catlinks .= '</select>'."\n".              $catlinks .= '</select>'."\n";
                          '&nbsp;<input type="submit" name="gocats" value="'.&mt('Change').'" />';          } elsif ($cat ne 'instcode') {
               $catlinks .= '&nbsp;'.&mt('(No subcategories)');
         }          }
       } else {
           $selitem = 'currcat_0';
     }      }
     $catlinks .= $currcat_str.'</td></tr></table></td>';      $catlinks .= $currcat_str.'</td></tr></table></td>';
     return $catlinks;      return ($catlinks,$has_subcats,$selitem);
   }
   
   sub main_category_selector {
       my (@cats) = @_;
       my $maincatlinks = '<select name="currcat_0" onchange="setCatDepth('."'0'".');this.form.submit();">'."\n";
       if (ref($cats[0]) eq 'ARRAY') {
           if (@{$cats[0]} > 1) {
               my $selected = '';
               if ($env{'form.currcat_0'} eq '') {
                   $selected = ' selected="selected"';    
               }
               $maincatlinks .= 
                   '<option value=""'.$selected.'>'.&mt('Select').'</option>'."\n";
           }
           for (my $i=0; $i<@{$cats[0]}; $i++) {
               my $name = $cats[0][$i];
               my $item = &escape($name).'::0';
               my $selected;
               if ($env{'form.currcat_0'} eq $item) {
                   $selected = ' selected="selected"';
               }
               $maincatlinks .= '<option value="'.$item.'"'.$selected.'>';
               if ($name eq 'instcode') {
                   $maincatlinks .= &mt('Official courses (with institutional codes)');
               } elsif ($name eq 'communities') {
                   $maincatlinks .= &mt('Communities');
               } else {
                   $maincatlinks .= $name;
               }
               $maincatlinks .= '</option>'."\n";
           }
           $maincatlinks .= '</select>'."\n";
       }
       return $maincatlinks;
 }  }
   
 sub get_depth_values {  sub get_depth_values {
Line 463  sub get_depth_values { Line 478  sub get_depth_values {
 }  }
   
 sub additional_filters {  sub additional_filters {
     my ($codedom) = @_;      my ($codedom,$has_subcats) = @_;
     my $output = '<table>';      my $output = '<table>';
       if (($env{'form.currcat_0'} ne 'instcode::0') && 
           ($env{'form.currcat_0'} ne '') && ($has_subcats)) {
           my $include_subcat_status;
           if ($env{'form.withsubcats'}) {
               $include_subcat_status = 'checked="checked" ';
           }
           my $counter = $env{'form.catalog_maxdepth'};
           if ($counter > 0) {
               if ($env{'form.state'} eq 'listing') {
                   $counter --;
               } elsif ($env{'form.currcat_'.$counter} eq '') {
                   $counter --;
               }
           }
           my ($catname) = split(/:/,$env{'form.currcat_'.$counter});
           if ($catname ne '') {
               $output .= '<tr><td><label>'.
                          '<input type="checkbox" name="withsubcats" value="1" '.
                          $include_subcat_status.'/>'.
                          &mt('Include subcategories within "[_1]"',
                              &unescape($catname)).'</label></td></tr>';
           }
       }
     my $show_selfenroll_status;      my $show_selfenroll_status;
     if ($env{'form.showselfenroll'}) {      if ($env{'form.showselfenroll'}) {
         $show_selfenroll_status = 'checked="checked" ';          $show_selfenroll_status = 'checked="checked" ';
     }      }
       my $selfenroll_text;
       if ($env{'form.currcat_0'} eq 'communities::0') {
           $selfenroll_text = &mt('Only show communities which allow self-enrollment');
       } else {
           $selfenroll_text = &mt('Only show courses which allow self-enrollment');
       }
       $output .= '<tr><td>'.
                  '<label><input type="checkbox" name="showselfenroll" value="1" '.
                  $show_selfenroll_status.'/>'.$selfenroll_text.
                  '</label></td></tr>';
     if (&user_is_dc($codedom)) {      if (&user_is_dc($codedom)) {
         my $showdetails_status;          my $showdetails_status;
         if ($env{'form.showdetails'}) {          if ($env{'form.showdetails'}) {
Line 479  sub additional_filters { Line 527  sub additional_filters {
              $showhidden_status = 'checked="checked" ';               $showhidden_status = 'checked="checked" ';
         }          }
         my $dc_title = &Apache::lonnet::plaintext('dc');          my $dc_title = &Apache::lonnet::plaintext('dc');
           my ($details_text,$hidden_text);
           if ($env{'form.currcat_0'} eq 'communities::0') {
               $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);
           } else {
               $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);
           }
         $output .= '<tr><td>'."\n".          $output .= '<tr><td>'."\n".
                    '<label><input type="checkbox" name="showdetails" value="1" '.                     '<label><input type="checkbox" name="showdetails" value="1" '.
                    $showdetails_status.'/>'."\n".                     $showdetails_status.'/>'.$details_text.
                    &mt('Show full details for each course ([_1] only)',$dc_title).  
                    '</label>'."\n".'</td></tr><tr><td>'.                     '</label>'."\n".'</td></tr><tr><td>'.
                    '<label><input type="checkbox" name="showhidden" value="1" '.                     '<label><input type="checkbox" name="showhidden" value="1" '.
                    $showhidden_status.'/>'.                     $showhidden_status.'/>'.$hidden_text.
                    &mt('Include courses set to be hidden from catalog ([_1] only)',$dc_title).  
                    '</label>'."\n".'</td></tr>';                     '</label>'."\n".'</td></tr>';
     }      }
     $output .= '<tr><td>'.      $output .= '</table><br />';
                '<label><input type="checkbox" name="showselfenroll" value="1" '.  
                $show_selfenroll_status.'/>'.  
                &mt('Only show courses which allow self-enrollment').  
                '</label></td></tr></table><br />';  
     return $output;      return $output;
 }  }
   
Line 510  sub user_is_dc { Line 560  sub user_is_dc {
     return;      return;
 }  }
   
 sub recurse_options {  
     my ($currkey,$currlist,$level,$cat,$cat_options,$data,$by_year,$by_sem,$by_dept) = @_;  
     if (ref($currlist) eq 'HASH') {  
         $level ++;  
         foreach my $key (sort(keys(%{$currlist}))) {  
             $$data[$level-1]= $key;  
             &recurse_options($key,$currlist->{$key},$level,$cat,$cat_options,$data,$by_year,$by_sem,$by_dept);  
         }  
     } else {  
         $level --;  
         my @contents = split(/","/,$currlist);  
         foreach my $item (@contents) {  
             if (!grep(/^\Q$item\E$/,@{$cat_options->{$cat}})) {  
                 push(@{$cat_options->{$cat}},$item);  
             }  
             if ($level == 3) {  
                 if (!grep/^\Q$item\E$/,@{$by_year->{$data->[1]}->{$currkey}}) {  
                     push(@{$by_year->{$data->[1]}->{$currkey}},$item);                   
                 }  
                 if (!grep/^\Q$item\E$/,@{$by_sem->{$data->[2]}->{$currkey}}) {  
                     push(@{$by_sem->{$data->[2]}->{$currkey}},$item);  
                 }  
                 if (!grep/^\Q$item\E$/,@{$by_dept->{$currkey}}) {  
                     push(@{$by_dept->{$currkey}},$item);  
                 }  
   
             }  
         }  
     }  
     return $level;  
 }  
   
 sub build_javascript {  
     my ($by_year,$by_sem,$by_dept,$cat_order,$codetitles) = @_;  
     my @unsorted = keys(%{$by_year});  
     my @sorted_yrs;   
     &Apache::courseclassifier::sort_cats('0',$cat_order,$codetitles,\@unsorted,\@sorted_yrs);  
     my $output = 'var idcse_by_yr_year = new Array("'.join('","',@sorted_yrs).'");'."\n".  
                  'var idcse_by_yr_dept = new Array('.scalar(@sorted_yrs).');'."\n".  
                  'var idcse_by_yr_num = new Array('.scalar(@sorted_yrs).');'."\n";  
     for (my $i=0; $i<@sorted_yrs; $i++) {  
         my $numkeys = keys(%{$by_year->{$sorted_yrs[$i]}});  
         $output .= " idcse_by_yr_num[$i] = new Array($numkeys);\n";  
         if (ref($by_year->{$sorted_yrs[$i]}) eq 'HASH') {  
             @unsorted = keys(%{$by_year->{$sorted_yrs[$i]}});  
             my @sorted_depts;  
             &Apache::courseclassifier::sort_cats('2',$cat_order,$codetitles,\@unsorted,\@sorted_depts);  
             $output .= qq| idcse_by_yr_dept[$i] = new Array ("|.join('","',@sorted_depts).'");'."\n";  
             for (my $j=0; $j<@sorted_depts; $j++) {  
                 $output .= qq| idcse_by_yr_num[$i][$j] = new Array ("|;  
                 $output .= join('","',sort(@{$by_year->{$sorted_yrs[$i]}->{$sorted_depts[$j]}})).'");'."\n";  
             }  
         }  
     }  
     @unsorted = keys(%{$by_sem});  
     my @sorted_sems;  
     &Apache::courseclassifier::sort_cats('1',$cat_order,$codetitles,\@unsorted,\@sorted_sems);  
     $output .=  'idcse_by_sem_sems = new Array("'.join('","',@sorted_sems).'");'."\n".  
                 'idcse_by_sem_dept = new Array('.scalar(@sorted_sems).');'."\n".  
                 'idcse_by_sem_num = new Array('.scalar(@sorted_sems).');'."\n";  
     for (my $i=0; $i<@sorted_sems; $i++) {  
         my $numkeys = keys(%{$by_sem->{$sorted_sems[$i]}});  
         $output .= " idcse_by_sem_num[$i] = new Array($numkeys);\n";  
         if (ref($by_sem->{$sorted_sems[$i]}) eq 'HASH') {  
             @unsorted = keys(%{$by_sem->{$sorted_sems[$i]}});  
             my @sorted_depts;  
             &Apache::courseclassifier::sort_cats('2',$cat_order,$codetitles,\@unsorted,\@sorted_depts);  
             $output .= qq| idcse_by_sem_dept[$i] = new Array("|.join('","',@sorted_depts).'");'."\n";  
             for (my $j=0; $j<@sorted_depts; $j++) {  
                 $output .= qq| idcse_by_sem_num[$i][$j] = new Array ("|.join('","',sort(@{$by_sem->{$sorted_sems[$i]}->{$sorted_depts[$j]}})).'");'."\n";  
             }  
         }  
     }  
     @unsorted = keys(%{$by_dept});  
     my @sorted_deps;  
     &Apache::courseclassifier::sort_cats('2',$cat_order,$codetitles,\@unsorted,\@sorted_deps);  
     $output .= 'idcse_by_dep = new Array('.scalar(@sorted_deps).');'."\n";   
     for (my $k=0; $k<@sorted_deps; $k++) {  
         $output .= qq| idcse_by_dep[$k] = new Array ("|.join('","',sort(@{$by_dept->{$sorted_deps[$k]}})).'");'."\n";  
     }  
     return $output;  
 }  
   
 sub search_official_courselist {  sub search_official_courselist {
     my ($domain,$numtitles) = @_;      my ($domain,$numtitles) = @_;
     my $instcode;      my $instcode = &Apache::courseclassifier::instcode_search_str($domain,$numtitles);
     if (defined($numtitles) && $numtitles == 0) {  
         $instcode = '.+';  
     } else {  
         my (%codedefaults,@code_order);  
         my $defaults_result =   
             &Apache::lonnet::auto_instcode_defaults($domain,\%codedefaults,  
                                                     \@code_order);  
         if ($defaults_result eq 'ok') {  
             $instcode ='^';  
             foreach my $item (@code_order) {  
                 if ($env{'form.'.$item} eq '0' ) {  
                     $instcode .= $codedefaults{$item};   
                 } else {  
                     $instcode .= $env{'form.'.$item};  
                 }  
             }  
             $instcode .= '$';  
         } else {  
             $instcode = '.';  
         }  
     }  
     my $showhidden;      my $showhidden;
     if (&user_is_dc($domain)) {      if (&user_is_dc($domain)) {
         $showhidden = $env{'form.showhidden'};          $showhidden = $env{'form.showhidden'};
Line 629  sub search_official_courselist { Line 575  sub search_official_courselist {
 }  }
   
 sub search_courselist {  sub search_courselist {
     my ($domain) = @_;      my ($domain,$subcats) = @_;
     my $cat_maxdepth = $env{'form.catalog_maxdepth'};      my $cat_maxdepth = $env{'form.catalog_maxdepth'};
     my $filter = $env{'form.currcat_'.$cat_maxdepth};      my $filter = $env{'form.currcat_'.$cat_maxdepth};
     if (($filter eq '') && ($cat_maxdepth > 0)) {      if (($filter eq '') && ($cat_maxdepth > 0)) {
Line 637  sub search_courselist { Line 583  sub search_courselist {
         $filter = $env{'form.currcat_'.$shallower};          $filter = $env{'form.currcat_'.$shallower};
     }      }
     my %courses;      my %courses;
       my $filterstr;
     if ($filter ne '') {      if ($filter ne '') {
         my $showhidden;          if ($env{'form.withsubcats'}) {
               if (ref($subcats) eq 'HASH') {
                   if (ref($subcats->{$filter}) eq 'ARRAY') {
                       $filterstr = join('&',@{$subcats->{$filter}});
                       if ($filterstr ne '') {
                           $filterstr = $filter.'&'.$filterstr;
                       }
                   } else {
                       $filterstr = $filter;
                   }
               } else {
                   $filterstr = $filter;
               }  
           } else {
               $filterstr = $filter; 
           }
           my ($showhidden,$typefilter);
         if (&user_is_dc($domain)) {          if (&user_is_dc($domain)) {
             $showhidden = $env{'form.showhidden'};              $showhidden = $env{'form.showhidden'};
         }          }
           if ($env{'form.currcat_0'} eq 'communities::0') {
               $typefilter = 'Community';
           } else {
               $typefilter = '.';
           }
         %courses =           %courses = 
             &Apache::lonnet::courseiddump($domain,'.',1,'.','.','.',undef,undef,              &Apache::lonnet::courseiddump($domain,'.',1,'.','.','.',undef,undef,
                                           '.',1,$env{'form.showselfenroll'},                                            $typefilter,1,$env{'form.showselfenroll'},
                                           $filter,$showhidden,'coursecatalog');                                            $filterstr,$showhidden,'coursecatalog');
     }      }
     return %courses;      return %courses;
 }  }
   
 sub print_course_listing {  sub print_course_listing {
     my ($domain,$numtitles,$trails,$allitems) = @_;      my ($domain,$numtitles,$trails,$allitems,$subcats) = @_;
     my $output;      my $output;
     my %courses;      my %courses;
     my $knownuser = &user_is_known();      my $knownuser = &user_is_known();
Line 673  sub print_course_listing { Line 641  sub print_course_listing {
         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);
         } else {          } else {
             %courses = &search_courselist($domain);              %courses = &search_courselist($domain,$subcats);
         }          }
         if (keys(%courses) == 0) {          if (keys(%courses) == 0) {
             $output = &mt('No courses match the criteria you selected.');              if ($env{'form.currcat_0'} eq 'communities::0') {
                   $output = &mt('No communities match the criteria you selected.');
               } else {
                   $output = &mt('No courses match the criteria you selected.');
               }
             return $output;              return $output;
         }          }
         if (($knownuser) && (!$env{'form.showdetails'}) && (!&user_is_dc($domain))) {          if (($knownuser) && (!$env{'form.showdetails'}) && (!&user_is_dc($domain))) {
Line 689  sub print_course_listing { Line 661  sub print_course_listing {
     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,\%courses,$details,undef,$now,\%domconfig,$trails,$allitems);
     $output .= &Apache::lonhtmlcommon::echo_form_input(['coursenum','state','catalogfilter','sortby','showdetails']);      $output .= "\n".'<form name="linklaunch" method="post" action="">'.
                  '<input type="hidden" name="backto" value="coursecatalog" />'.
                  '<input type="hidden" name="courseid" value="" />'.
                  &Apache::lonhtmlcommon::echo_form_input(['catalogfilter','courseid']).'</form>';
     return $output;      return $output;
 }  }
   
Line 731  sub construct_data_table { Line 706  sub construct_data_table {
             $output .=              $output .=
               '<th>'.&mt('Default Access Dates for Students').'</th>'.                '<th>'.&mt('Default Access Dates for Students').'</th>'.
               '<th>'.&mt('Student Counts').'</th>'.                '<th>'.&mt('Student Counts').'</th>'.
               '<th>'.&mt('Auto-enrollment of <br />registered students').'</th>';                '<th>'.&mt('Auto-enrollment of[_1]registered students','<br />').'</th>';
         } else {          } else {
             $output .= '<th>'.&mt('Details').'</th>';              $output .= '<th>'.&mt('Details').'</th>';
         }          }
Line 790  sub build_courseinfo_hash { Line 765  sub build_courseinfo_hash {
         $cleandesc=~s/'/\\'/g;          $cleandesc=~s/'/\\'/g;
         $cleandesc =~ s/^\s+//;          $cleandesc =~ s/^\s+//;
         my ($cdom,$cnum)=split(/\_/,$course);          my ($cdom,$cnum)=split(/\_/,$course);
         my ($descr,$instcode,$singleowner,$ttype,$selfenroll_types,          my ($instcode,$singleowner,$ttype,$selfenroll_types,
             $selfenroll_start,$selfenroll_end,@owners,%ownernames,$categories);              $selfenroll_start,$selfenroll_end,@owners,%ownernames,$categories);
         if (ref($courses->{$course}) eq 'HASH') {          if (ref($courses->{$course}) eq 'HASH') {
             $descr = $courses->{$course}{'description'};              $descr = $courses->{$course}{'description'};
Line 809  sub build_courseinfo_hash { Line 784  sub build_courseinfo_hash {
             }              }
         }          }
         foreach my $owner (@owners) {          foreach my $owner (@owners) {
             my ($ownername,$ownerdom) = @_;               my ($ownername,$ownerdom); 
             if ($owner =~ /:/) {              if ($owner =~ /:/) {
                 ($ownername,$ownerdom) = split(/:/,$owner);                  ($ownername,$ownerdom) = split(/:/,$owner);
             } else {              } else {
Line 878  sub build_courseinfo_hash { Line 853  sub build_courseinfo_hash {
                 }                  }
             }              }
             if ($startaccess) {              if ($startaccess) {
                 $accessdates .= &mt('<i>From:</i> ').$startaccess.'<br />';                  $accessdates .= '<i>'.&mt('From:[_1]','</i> '.$startaccess).'<br />';
             }              }
             if ($endaccess) {              if ($endaccess) {
                 $accessdates .= &mt('<i>To:</i> ').$endaccess.'<br />';                  $accessdates .= '<i>'.&mt('To:[_1]','</i> '.$endaccess).'<br />';
             }              }
             if (($selfenroll_types ne '') &&               if (($selfenroll_types ne '') && 
                 ($selfenroll_end > 0 && $selfenroll_end > $now)) {                  ($selfenroll_end > 0 && $selfenroll_end > $now)) {
Line 902  sub build_courseinfo_hash { Line 877  sub build_courseinfo_hash {
                     if ($selfenroll_start_access || $selfenroll_end_access) {                      if ($selfenroll_start_access || $selfenroll_end_access) {
                         $accessdates .= '<br/><br /><i>'.&mt('Self-enrollers:').'</i><br />';                          $accessdates .= '<br/><br /><i>'.&mt('Self-enrollers:').'</i><br />';
                         if ($selfenroll_start_access) {                          if ($selfenroll_start_access) {
                             $accessdates .= &mt('<i>From:</i> ').$selfenroll_start_access.'<br />';                              $accessdates .= '<i>'.&mt('From:[_1]','</i> '.$selfenroll_start_access).'<br />';
                         }                          }
                         if ($selfenroll_end_access) {                          if ($selfenroll_end_access) {
                             $accessdates .= &mt('<i>To:</i> ').$selfenroll_end_access.'<br />';                              $accessdates .= '<i>'.&mt('To:[_1]','</i> '.$selfenroll_end_access).'<br />';
                         }                          }
                     }                      }
                 }                  }
Line 940  sub count_students { Line 915  sub count_students {
         $student_count{$data->[$idx{'status'}]} ++;          $student_count{$data->[$idx{'status'}]} ++;
     }      }
   
     my $countslist = &mt('[quant,_1,section]',$numsec).':<br />';      my $countslist = &mt('[quant,_1,section:,sections:,No sections]',$numsec).'<br />';
     foreach my $status ('Active','Future') {      foreach my $status ('Active','Future') {
         $countslist .= '<nobr>'.$status_title{$status}.': '.          $countslist .= '<span class="LC_nobreak">'.$status_title{$status}.': '.
                        $student_count{$status}.'</nobr><br />';                         $student_count{$status}.'</span><br />';
     }      }
     return $countslist;      return $countslist;
 }  }
Line 992  sub courseinfo_row { Line 967  sub courseinfo_row {
                '<td>'.$xlist_items.'</td>'.                 '<td>'.$xlist_items.'</td>'.
                '<td>'.$title.'&nbsp;<font size="-2">';                 '<td>'.$title.'&nbsp;<font size="-2">';
     if ($showsyllabus) {      if ($showsyllabus) {
         $output .= &Apache::loncommon::syllabuswrapper(&mt('Syllabus'),$cnum,$cdom);          $output .= '<a href="javascript:ToSyllabus('."'$cdom','$cnum'".')">'.&mt('Syllabus').'</a>';
     } else {      } else {
         $output .= '&nbsp;';          $output .= '&nbsp;';
     }      }
Line 1016  sub courseinfo_row { Line 991  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="/adm/selfenroll?cid='.$course.'">'.&mt('Enroll in course').'</a></td>';                  $output .= '<td><a href="javascript:ToSelfenroll('."'$course'".')">'.&mt('Enroll in course').'</a></td>';
             }              }
             $selfenroll = 1;              $selfenroll = 1;
         }          }
Line 1046  sub identify_sections { Line 1021  sub identify_sections {
         }          }
     }      }
     @secnums = sort {$a <=> $b} @secnums;      @secnums = sort {$a <=> $b} @secnums;
     my $seclist = join(', ',@secnums);      $seclist = join(', ',@secnums);
     my $numsec = @secnums;      my $numsec = @secnums;
     return ($seclist,$numsec);      return ($seclist,$numsec);
 }  }
Line 1083  sub get_valid_classes { Line 1058  sub get_valid_classes {
     }      }
     if ($totalitems > 0) {      if ($totalitems > 0) {
         if (@{$validations{'sections'}}) {          if (@{$validations{'sections'}}) {
             $response = &mt('Sections: ').              $response = &mt('Sections:').' '.
                         join(', ',@{$validations{'sections'}}).'<br />';                          join(', ',@{$validations{'sections'}}).'<br />';
         }          }
         if (@{$validations{'xlists'}}) {          if (@{$validations{'xlists'}}) {
             $response .= &mt('Courses: ').              $response .= &mt('Courses:').' '.
                         join(', ',@{$validations{'xlists'}});                          join(', ',@{$validations{'xlists'}});
         }          }
     }      }
     return $response;      return $response;
 }  }
   
 sub javascript_select_filler {  
     my ($formname,$scripttext,$codetitles,$longtitles_str,$allidlist) = @_;  
     my $output = <<END;  
 function courseSet() {  
     var longtitles = new Array ("$longtitles_str");  
     var valyr = document.$formname.Year.options[document.$formname.Year.selectedIndex].value  
     var valsem  = document.$formname.Semester.options[document.$formname.Semester.selectedIndex].value  
     var valdept = document.$formname.Department.options[document.$formname.Department.selectedIndex].value  
     var valclass = document.$formname.Number.options[document.$formname.Number.selectedIndex].value  
     var idyears = new Array("$allidlist");  
     var idyr = -1;  
     var idsem = -1;  
     var iddept = -1;  
     document.$formname.Number.length = 0;  
   
     $scripttext  
   
     selYear = document.$formname.Year.selectedIndex-1;  
     selSemester = document.$formname.Semester.selectedIndex-1;  
     selDepartment = document.$formname.Department.selectedIndex-1;  
     if (selYear == -1) {  
         if (selSemester == -1) {  
             if (selDepartment > -1) {  
                 document.$formname.Number.options[0] =  new Option('All','0',false,false);  
                 for (var k=0; k<idcse_by_dep[selDepartment].length; k++) {  
                     document.$formname.Number.options[k+1] = new Option(idcse_by_dep[selDepartment][k],idcse_by_dep[selDepartment][k],false,false);  
   
                 }  
             }   
             else {  
                 document.$formname.Number.options[0] = new Option("All","0",true,true);  
             }  
         }  
         else {  
             if (selDepartment > -1) {  
                 for (var i=0; i<idcse_by_sem_sems.length; i++) {  
                     if (idcse_by_sem_sems[i] == valsem) {  
                         idsem = i;  
                     }  
                 }  
                 if (idsem != -1) {  
                     for (var i=0; i<idcse_by_sem_dept[idsem].length; i++) {  
                         if (idcse_by_sem_dept[idsem][i] == valdept) {  
                             iddept = i;  
                         }  
                     }  
                 }  
                 if (iddept != -1) {  
                     document.$formname.Number.options[0] =  new Option('All','0',false,false);  
                     for (var k=0; k<idcse_by_sem_num[idsem][iddept].length; k++) {  
                         document.$formname.Number.options[k+1] = new Option(idcse_by_sem_num[idsem][iddept][k],idcse_by_sem_num[idsem][iddept][k],false,false);  
                     }  
                 }  
                 else {  
                     document.$formname.Number.options[0] =  new Option('No courses','0',true,true);  
                 }  
             }  
             else {  
                 document.$formname.Number.options[0] = new Option("All","0",true,true);  
             }  
         }  
     }  
     else {  
         if (selSemester == -1) {  
             if (selDepartment > -1) {  
                 for (var i=0; i<idcse_by_yr_year.length; i++) {  
                     if (idcse_by_yr_year[i] == valyr) {  
                         idyr = i;  
                     }  
                 }  
                 if (idyr != -1) {        
                     for (var i=0; i<idcse_by_yr_dept[idyr].length; i++) {  
                         if (idcse_by_yr_dept[idyr][i] == valdept) {  
                             iddept = i;  
                         }  
                     }  
                 }  
                 if (iddept != -1) {  
                     document.$formname.Number.options[0] =  new Option('All','0',false,false);  
                     for (var k=0; k<idcse_by_yr_num[idyr][iddept].length; k++) {  
                         document.$formname.Number.options[k+1] = new Option(idcse_by_yr_num[idyr][iddept][k],idcse_by_yr_num[idyr][iddept][k],false,false);  
                     }  
                 }   
                 else {  
                     document.$formname.Number.options[0] =  new Option('No courses','0',true,true);  
                 }  
             }  
             else {  
                 document.$formname.Number.options[0] = new Option("All","0",true,true);  
             }  
         }  
         else {  
             if (selDepartment > -1) {  
                 for (var k=0; k<idyears.length; k++) {  
                     if (idyears[k] == valyr) {  
                         idyr = k;  
                     }  
                 }  
                 if (idyr != -1) {  
                     for (var k=0; k<idsems[idyr].length; k++) {  
                         if (idsems[idyr][k] == valsem) {  
                             idsem = k;  
                         }  
                     }  
                 }  
                 if (idsem != -1) {  
                     for (var k=0; k<idcodes[idyr][idsem].length; k++) {  
                         if (idcodes[idyr][idsem][k] == valdept) {  
                             iddept = k;  
                         }  
                     }  
                 }  
                 if (iddept != -1) {  
                     document.$formname.Number.options[0] =  new Option('All','0',false,false);  
                     for (var i=0; i<idcourses[idyr][idsem][iddept].length; i++) {  
                         var display = idcourses[idyr][idsem][iddept][i];  
                         if (longtitles[3] == 1) {  
                             if (idcourseslongs[idyr][idsem][iddept][i] != "") {  
                                 display = idcourseslongs[idyr][idsem][iddept][i]  
                             }  
                         }  
                         document.$formname.Number.options[i+1] = new Option(display,idcourses[idyr][idsem][iddept][i],false,false)  
                     }  
                 }   
                 else {  
                     document.$formname.Number.options[0] =  new Option('No courses','0',true,true);  
                 }  
             }   
             else {  
                 document.$formname.Number.options[0] =  new Option('All','0',true,true);  
             }  
         }  
         document.$formname.Number.selectedIndex = 0  
     }  
 }  
 END  
     return $output;  
 }  
   
 sub autoenroll_info {  sub autoenroll_info {
     my ($coursehash,$now,$seclist,$xlist_items,$code,$owners,$cdom,$cnum) = @_;      my ($coursehash,$now,$seclist,$xlist_items,$code,$owners,$cdom,$cnum) = @_;
     my $autoenrolldates = &mt('Not enabled');      my $autoenrolldates = &mt('Not enabled');
Line 1252  sub autoenroll_info { Line 1088  sub autoenroll_info {
                    &get_valid_classes($seclist,$xlist_items,$code,                     &get_valid_classes($seclist,$xlist_items,$code,
                                       $owners,$cdom,$cnum);                                        $owners,$cdom,$cnum);
                 if ($valid_classes ne '') {                  if ($valid_classes ne '') {
                     $autoenrolldates = &mt('Not enabled<br />Starts: ').                      $autoenrolldates = &mt('Not enabled').'<br />'
                                        $autostart.'<br />'.$valid_classes;                }                                        .&mt('Starts: [_1]',$autostart)
                                         .'<br />'.$valid_classes;
                   }
             }              }
         } else {          } else {
             if ($coursehash->{'internal.autoend'} && $coursehash->{'internal.autoend'} < $now) {              if ($coursehash->{'internal.autoend'} && $coursehash->{'internal.autoend'} < $now) {
                 $autoenrolldates = &mt('Not enabled<br />Ended: ').$autoend;                  $autoenrolldates = &mt('Not enabled').'<br />'
                                     .&mt('Ended: [_1]',$autoend);
             } else {              } else {
                 my $valid_classes = &get_valid_classes($seclist,$xlist_items,                  my $valid_classes = &get_valid_classes($seclist,$xlist_items,
                                                        $code,$owners,$cdom,$cnum);                                                         $code,$owners,$cdom,$cnum);
                 if ($valid_classes ne '') {                  if ($valid_classes ne '') {
                     $autoenrolldates = &mt('Currently enabled<br />').                      $autoenrolldates = &mt('Currently enabled').'<br />'.
                                        $valid_classes;                                         $valid_classes;
                 }                  }
             }              }

Removed from v.1.35  
changed lines
  Added in v.1.53.4.3


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