--- loncom/interface/lonhelper.pm 2006/05/09 18:15:39 1.143 +++ loncom/interface/lonhelper.pm 2006/07/17 16:26:09 1.157 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # .helper XML handler to implement the LON-CAPA helper # -# $Id: lonhelper.pm,v 1.143 2006/05/09 18:15:39 albertel Exp $ +# $Id: lonhelper.pm,v 1.157 2006/07/17 16:26:09 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -183,7 +183,9 @@ use Apache::File; use Apache::lonxml; use Apache::lonlocal; use Apache::lonnet; - +use Apache::longroup; +use Apache::lonselstudent; +use LONCAPA; # Register all the tags with the helper, so the helper can # push and pop them @@ -362,6 +364,7 @@ use Apache::loncommon; use Apache::File; use Apache::lonlocal; use Apache::lonnet; +use LONCAPA; sub new { my $proto = shift; @@ -467,9 +470,8 @@ sub _saveVars { sub _varsInFile { my $self = shift; my @vars = (); - for my $key (keys %{$self->{VARS}}) { - push @vars, &Apache::lonnet::escape($key) . '=' . - &Apache::lonnet::escape($self->{VARS}->{$key}); + for my $key (keys(%{$self->{VARS}})) { + push(@vars, &escape($key) . '=' . &escape($self->{VARS}->{$key})); } return join ('&', @vars); } @@ -484,7 +486,7 @@ sub declareVar { $self->{VARS}->{$var} = ''; } - my $envname = 'form.' . $var . '.forminput'; + my $envname = 'form.' . $var . '_forminput'; if (defined($env{$envname})) { if (ref($env{$envname})) { $self->{VARS}->{$var} = join('|||', @{$env{$envname}}); @@ -1021,6 +1023,81 @@ sub postprocess { } 1; +package Apache::lonhelper::skip; + +=pod + +=head1 Elements + +=head2 Element: skipX<skip> + +The <skip> tag allows you define conditions under which the current state +should be skipped over and define what state to skip to. + + <state name="SKIP"> + <skip> + <clause> + #some code that decides whether to skip the state or not + </clause> + <nextstate>FINISH</nextstate> + </skip> + <message nextstate="FINISH">A possibly skipped state</message> + </state> + +=cut + +no strict; +@ISA = ("Apache::lonhelper::element"); +use strict; + +BEGIN { + &Apache::lonhelper::register('Apache::lonhelper::skip', + ('skip')); +} + +sub new { + my $ref = Apache::lonhelper::element->new(); + bless($ref); +} + +sub start_skip { + my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; + + if ($target ne 'helper') { + return ''; + } + # let <cluase> know what text to skip to + $paramHash->{SKIPTAG}='/skip'; + return ''; +} + +sub end_skip { + my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; + + if ($target ne 'helper') { + return ''; + } + Apache::lonhelper::skip->new(); + return ''; +} + +sub render { + my $self = shift; + return ''; +} +# If a NEXTSTATE is set, switch to it +sub preprocess { + my ($self) = @_; + + if (defined($self->{NEXTSTATE})) { + $helper->changeState($self->{NEXTSTATE}); + } + + return 1; +} + +1; + package Apache::lonhelper::choices; =pod @@ -1203,7 +1280,7 @@ sub render { function checkall(value, checkName) { for (i=0; i<document.forms.helpform.elements.length; i++) { ele = document.forms.helpform.elements[i]; - if (ele.name == checkName + '.forminput') { + if (ele.name == checkName + '_forminput') { document.forms.helpform.elements[i].checked=value; } } @@ -1276,7 +1353,7 @@ BUTTONS foreach my $choice (@{$self->{CHOICES}}) { my $id = &new_id(); $result .= "<tr>\n<td width='20'> </td>\n"; - $result .= "<td valign='top'><input type='$type' name='$var.forminput'" + $result .= "<td valign='top'><input type='$type' name='${var}_forminput'" . " value='" . HTML::Entities::encode($choice->[1],"<>&\"'") . "'"; @@ -1295,7 +1372,7 @@ BUTTONS $choiceLabel. "</label></td>"; if ($choice->[4]) { $result .='<td><input type="text" size="5" name="' - .$choice->[4].'.forminput" value="' + .$choice->[4].'_forminput" value="' .$choice->[5].'" /></td>'; } $result .= "</tr>\n"; @@ -1310,7 +1387,7 @@ BUTTONS # given, switch to it sub postprocess { my $self = shift; - my $chosenValue = $env{'form.' . $self->{'variable'} . '.forminput'}; + my $chosenValue = $env{'form.' . $self->{'variable'} . '_forminput'}; if (!defined($chosenValue) && !$self->{'allowempty'}) { $self->{ERROR_MSG} = @@ -1334,7 +1411,7 @@ sub postprocess { } if ($choice->[4]) { my $varname = $choice->[4]; - $helper->{'VARS'}->{$varname} = $env{'form.'."$varname.forminput"}; + $helper->{'VARS'}->{$varname} = $env{'form.'."${varname}_forminput"}; } } return 1; @@ -1443,7 +1520,7 @@ sub render { $checkedChoices{$self->{CHOICES}->[0]->[1]} = 1; } - $result .= "<select name='${var}.forminput'>\n"; + $result .= "<select name='${var}_forminput'>\n"; foreach my $choice (@{$self->{CHOICES}}) { $result .= "<option value='" . HTML::Entities::encode($choice->[1],"<>&\"'") @@ -1469,7 +1546,7 @@ sub render { # given, switch to it sub postprocess { my $self = shift; - my $chosenValue = $env{'form.' . $self->{'variable'} . '.forminput'}; + my $chosenValue = $env{'form.' . $self->{'variable'} . '_forminput'}; if (!defined($chosenValue) && !$self->{'allowempty'}) { $self->{ERROR_MSG} = "You must choose one or more choices to" . @@ -1608,8 +1685,6 @@ sub render { $date->min(0); } - &Apache::lonnet::logthis("date mode "); - if ($anytime) { $onclick = "onclick=\"javascript:updateCheck(this.form,'${var}anytime',false)\""; } @@ -2024,7 +2099,7 @@ sub render { function checkall(value, checkName) { for (i=0; i<document.forms.helpform.elements.length; i++) { ele = document.forms.helpform.elements[i]; - if (ele.name == checkName + '.forminput') { + if (ele.name == checkName + '_forminput') { document.forms.helpform.elements[i].checked=value; } } @@ -2123,12 +2198,12 @@ BUTTONS } $col .= "<td align='center'><input type='checkbox' name ='$option_var". - ".forminput' value='". + "_forminput' value='". $resource_name . "' $checked /> </td>"; } } - $col .= "<td align='center'><input type='$inputType' name='${var}.forminput' "; + $col .= "<td align='center'><input type='$inputType' name='${var}_forminput' "; if (%defaultSymbs) { my $symb=$resource->symb(); if (exists($defaultSymbs{$symb})) { @@ -2157,7 +2232,7 @@ BUTTONS my $resource_name = &HTML::Entities::encode(&$valueFunc($resource),"<>&\"'"); if ($addparts && (scalar(@{$resource->parts}) > 1)) { - $col .= "<select onclick=\"javascript:updateRadio(this.form,'${var}.forminput','$resource_name');updateHidden(this.form,'$id','${var}');\" name='part_$id.forminput'>\n"; + $col .= "<select onclick=\"javascript:updateRadio(this.form,'${var}_forminput','$resource_name');updateHidden(this.form,'$id','${var}');\" name='part_${id}_forminput'>\n"; $col .= "<option value=\"$part\">All Parts</option>\n"; foreach my $part (@{$resource->parts}) { $col .= "<option value=\"$part\">Part: $part</option>\n"; @@ -2179,14 +2254,14 @@ BUTTONS } } function updateHidden(form,id,name) { - var select=form['part_'+id+'.forminput']; - var hidden=form[name+'_part.forminput']; + var select=form['part_'+id+'_forminput']; + var hidden=form[name+'_part_forminput']; var which=select.selectedIndex; hidden.value=select.options[which].value; } // --> </script> -<input type="hidden" name="${var}_part.forminput" /> +<input type="hidden" name="${var}_part_forminput" /> RADIO $env{'form.condition'} = !$self->{'toponly'}; @@ -2275,120 +2350,6 @@ use strict; use Apache::lonlocal; use Apache::lonnet; -# -# Utility function used when rendering the <student> tag. -# This function renders a segment of course personel -# Personel are broken up by the helper into past, current and -# future...each one gets is own subpage of selection. -# This sub renders one of these pages. -# Parameters: -# $sections - Set of sections in the course (hash reference). -# $students - Students in the section. (ref to array of references -# to arrays). -# $formprefix - form path prefix for form element names -# This is used to make each form element -# so that the segments having to do with each -# set of students won't collide. -# $defaultusers - reference to a hash containng -# the set of users that should be on or off. -# Returns: -# HTML text to add to the rendering of the helper. -# -sub render_student_list { - my ($self, - $sections, $students, $formprefix, $defaultusers) = @_; - - my $multiselect = $self->{'multichoice'}; - my $result = ""; - - # If multiple selections are allowed, we have a listbox - # at the top which allows quick selections from each section - # as well as from categories of personnel. - - if ($multiselect) { - $result .= '<table><tr><td>'; - - my $size = scalar(keys(%$sections)); - $size += 3; # We have allstudents allpersonel nosection too. - if ($size > 5) { - $size = 5; - } - $result .= '<select multiple name="'.$formprefix - .'.chosensections" size="'.$size.'">'."\n"; - $result .= '<option name="allstudents">All Students</option>'; - $result .= '<option name="allpersonnel">All Course Personnel</option>'; - $result .= '<option name="nosection">No Section</option>'; - $result .= "\n"; - foreach my $sec (sort {lc($a) cmp lc($b)} (keys(%$sections))) { - $result .= '<option name="'.$sec.'">'.$sec.'</option>'."\n"; - } - $result .= '</td><td valign="top">'; - $result .= '<input type="button" name="'.$formprefix.'.select" value="Select" onclick=' - ."'selectSections(\"$formprefix.chosensections\", \"$formprefix\")'".' /></td>'; - $result .= '<td valign="top"><input type="button" name="'.$formprefix - .'.unselect" value="Unselect" onclick='. - "'unselectSections(\"$formprefix.chosensections\", \"$formprefix\")' ".' /></td></tr></table>'; - } - - # Now we list the students, but the form element type - # will depend on whether or not multiselect is true. - # True -> checkboxes. - # False -> radiobuttons. - - $result .= "<table border=\"2\">\n"; - $result .= '<tr><th></th><th align="center">Name</th>'."\n"; - $result .= ' <th align="center">Section</th>'."\n"; - $result .= ' <th align="center">Status</th>'."\n"; - $result .= ' <th align="center">Role</th>'."\n"; - $result .= ' <th align="center">Username : Domain</th></tr>'."\n"; - - my $input_type; - if ($multiselect) { - $input_type = "checkbox"; - } else { - $input_type = "radio"; - } - - my $checked = 0; - for my $student (@$students) { - $result .= '<tr><td><input type="'.$input_type.'" name="'. - $self->{'variable'}.".forminput".'"'; - my $user = $student->[0]; - - # Figure out which students are checked by default... - - if(%$defaultusers) { - if (exists ($defaultusers->{$user})) { - $result .= ' checked ="checked" '; - $checked = 1; - } - } elsif (!$self->{'multichoice'} && !$checked) { - $result .= ' checked="checked" '; - $checked = 1; # First one for radio if no default specified. - } - $result .= ' value="'. HTML::Entities::encode($user . ':' - .$student->[2] . ':' - .$student->[1] . ':' - .$student->[3] . ':' - .$student->[4] . ":" - .$formprefix, "<>&\"'") - ."\" /></td><td>\n"; - $result .= HTML::Entities::encode($student->[1], '<>&"') - . '</td><td align="center" >'."\n"; - $result .= HTML::Entities::encode($student->[2], '<>&"') - . '</td><td align="center">'."\n"; - $result .= HTML::Entities::encode($student->[3], '<>&"') - . '</td><td align="center">'."\n"; - $result .= HTML::Entities::encode($student->[4], '<>&"') - . '</td><td align="center">'."\n"; - $result .= HTML::Entities::encode($student->[0], '<>&"') - . '</td></tr>'."\n"; - } - $result .=" </table> <br /> <hr />\n"; - - return $result; -} - BEGIN { &Apache::lonhelper::register('Apache::lonhelper::student', ('student')); @@ -2433,136 +2394,6 @@ sub render { my $buttons = ''; my $var = $self->{'variable'}; - if ($self->{'multichoice'}) { - $result = <<SCRIPT; -<script type="text/javascript"> -// <!-- - - function findElement(name) { - var i; - var ele; - for(i =0; i < document.forms.helpform.elements.length; i++) { - ele = document.forms.helpform.elements[i]; - if(ele.name == name) { - return ele; - } - } - return null; - } - function isStudent(element) { - if(element.value.indexOf(":Student") != -1) { - return 1; - } - return 0; - } - function section(element) { - var i; - var info; - if (element.value.indexOf(':') != -1) { - info = element.value.split(':'); - return info[2]; - } else { - return ""; - } - } - function rightSubForm(element, which) { - if (element.value.indexOf(which) != -1) { - return true; - } else { - return false; - } - } - - function setAllStudents(value, which) { - var i; - var ele; - for (i =0; i < document.forms.helpform.elements.length; i++) { - ele = document.forms.helpform.elements[i]; - if(isStudent(ele) && rightSubForm(ele, which)) { - ele.checked=value; - } - } - } - function setAllCoursePersonnel(value, which) { - var i; - var ele; - for (i =0; i < document.forms.helpform.elements.length; i++) { - ele = document.forms.helpform.elements[i]; - if(!isStudent(ele) && rightSubForm(ele, which)) { - ele.checked = value; - } - } - } - function setSection(which, value, subform) { - var i; - var ele; - for (i =0; i < document.forms.helpform.elements.length; i++) { - ele = document.forms.helpform.elements[i]; - if (ele.value.indexOf(':') != -1) { - if ((section(ele) == which) && rightSubForm(ele, subform)) { - ele.checked = value; - } - } - } - } - - function setCheckboxes(listbox, which, value) { - var k; - var elem; - var what; - elem = findElement(listbox); - if (elem != null) { - for (k = 0; k < elem.length; k++) { - if (elem.options[k].selected) { - what = elem.options[k].text; - if (what == 'All Students') { - setAllStudents(value, which); - } else if (what == 'All Course Personnel') { - setAllCoursePersonnel(value, which); - } else if (what == 'No Section') { - setSection('',value, which); - } else { - setSection(what, value, which); - } - } - } - } - } - function selectSections(listbox, which) { - setCheckboxes(listbox, which, true); - - } - function unselectSections(listbox, which) { - setCheckboxes(listbox, which, false); - } - -// --> -</script> -SCRIPT - - my %lt=&Apache::lonlocal::texthash( - 'ocs' => "Select Only Current Students", - 'ues' => "Unselect Expired Students", - 'sas' => "Select All Students", - 'uas' => "Unselect All Students", - 'sfsg' => "Select Current Students for Section/Group", - 'ufsg' => "Unselect for Section/Group"); - - $buttons = <<BUTTONS; -<br /> -<table> - - <tr> - <td><input type="button" onclick="checkall(true, '$var')" value="$lt{'sas'}" /></td> - <td> <input type="button" onclick="checkall(false, '$var')" value="$lt{'uas'}" /><br /></td> - </tr> - -</table> -<br /> -BUTTONS -# $result .= $buttons; - -} if (defined $self->{ERROR_MSG}) { $result .= '<font color="#FF0000">' . $self->{ERROR_MSG} . '</font><br /><br />'; @@ -2582,125 +2413,31 @@ BUTTONS } + my ($course_personnel, + $current_members, + $expired_members, + $future_members) = + &Apache::lonselstudent::get_people_in_class($env{'request.course.sec'}); - # my $choices = []; - - # - # We need to parcel out the personel in to three arrays: - # $current_members[] - Contains those whose roles are currently active. - # $expired_members[] - Contains those whose roles have expired. - # $future_members[] - Contains those whose roles will become active in the - # future. - # - # Constants - my $section = &Apache::loncoursedata::CL_SECTION(); - my $fullname = &Apache::loncoursedata::CL_FULLNAME(); - my $status = &Apache::loncoursedata::CL_STATUS(); - my $start_date = &Apache::loncoursedata::CL_START(); - - my $current_members = []; - my $expired_members = []; - my $future_members = []; # Load up the non-students, if necessary - if ($self->{'coursepersonnel'}) { - my %coursepersonnel = Apache::lonnet::get_course_adv_roles(); - for (sort keys %coursepersonnel) { - for my $role (split /,/, $coursepersonnel{$_}) { - # extract the names so we can sort them - my @people; - - for (split /,/, $role) { - push @people, [split /:/, $role]; - } - - @people = sort { $a->[0] cmp $b->[0] } @people; - - for my $person (@people) { - push @$current_members, [join(':', @$person), $person->[0], '', $_]; - } - } - } - } - - - # Load up the students - my $classlist = &Apache::loncoursedata::get_classlist(); - my @keys = keys %{$classlist}; - # Sort by: Section, name - @keys = sort { - if ($classlist->{$a}->[$section] ne $classlist->{$b}->[$section]) { - return $classlist->{$a}->[$section] cmp $classlist->{$b}->[$section]; - } - return $classlist->{$a}->[$fullname] cmp $classlist->{$b}->[$fullname]; - } @keys; - - - - for (@keys) { - - if ( $classlist->{$_}->[$status] eq - 'Active') { - push @$current_members, [$_, $classlist->{$_}->[$fullname], - $classlist->{$_}->[$section], - $classlist->{$_}->[$status], 'Student']; - } else { - # Need to figure out if this user is future or - # Expired... If the start date is in the future - # the user is future...else expired. - - my $now = time; - if ($classlist->{$_}->[$start_date] > $now) { - push @$future_members, [$_, $classlist->{$_}->[$fullname], - $classlist->{$_}->[$section], - "Future", "Student"]; - } else { - push @$expired_members, [$_, $classlist->{$_}->[$fullname], - $classlist->{$_}->[$section], - "Expired", "Student"]; - } - - } - } - - - # Create a list of the sections that can be used to create the section - # selection list boxes: - # - my %sections; - for my $key (@keys) { - my $section_name = $classlist->{$key}->[$section]; - if ($section_name ne "") { - $sections{$section_name} = 1; - } + if ($self->{'coursepersonnel'}) { + unshift @$current_members, (@$course_personnel); } - if ($self->{'multichoice'}) { - - # The variable $choice_widget will have the html to make the choice - # selector. - my $size=5; - if (scalar(keys(%sections)) < 5) { - $size=scalar(keys(%sections)); - } - my $result = '<select multiple name="chosensections" size="'.$size.'">'."\n"; - foreach my $sec (sort {lc($a) cmp lc($b)} (keys(%sections))) { - $result .= "<option name=\"$sec\">$sec</option>\n"; - } - $result .= "<option>none</option></select>\n"; - - - } - # Current personel - $result .= $self->render_student_list(\%sections, - $current_members, - "current", - \%defaultUsers); + $result .= '<h4>Select Currently Enrolled Students and Active Course Personnel</h4>'; + $result .= &Apache::lonselstudent::render_student_list( $current_members, + "helpform", + "current", + \%defaultUsers, + $self->{'multichoice'}, + $self->{'variable'}, + 1); # If activeonly is not set then we can also give the expired students: @@ -2709,16 +2446,25 @@ BUTTONS # And future. - $result .= $self->render_student_list(\%sections, - $future_members, - "future", - \%defaultUsers); + $result .= '<h4>Select Future Enrolled Students and Future Course Personnel</h4>'; + + $result .= &Apache::lonselstudent::render_student_list( $future_members, + "helpform", + "future", + \%defaultUsers, + $self->{'multichoice'}, + $self->{'variable'}, + 0); # Past - $result .= $self->render_student_list(\%sections, - $expired_members, - "past", - \%defaultUsers); + $result .= '<h4>Select Previously Enrolled Students and Inactive Course Personnel</h4>'; + $result .= &Apache::lonselstudent::render_student_list($expired_members, + "helpform", + "past", + \%defaultUsers, + $self->{'multichoice'}, + $self->{'variable'}, + 0); } @@ -2729,7 +2475,7 @@ BUTTONS sub postprocess { my $self = shift; - my $result = $env{'form.' . $self->{'variable'} . '.forminput'}; + my $result = $env{'form.' . $self->{'variable'} . '_forminput'}; if (!$result && !$self->{'emptyallowed'}) { if ($self->{'coursepersonnel'}) { $self->{ERROR_MSG} = @@ -2914,7 +2660,7 @@ sub render { function checkall(value, checkName) { for (i=0; i<document.forms.helpform.elements.length; i++) { ele = document.forms.helpform.elements[i]; - if (ele.name == checkName + '.forminput') { + if (ele.name == checkName + '_forminput') { document.forms.helpform.elements[i].checked=value; } } @@ -3031,7 +2777,7 @@ BUTTONS my $id = &new_id(); $result .= '<tr><td align="right"' . " bgcolor='$color'>" . "<input $onclick type='$type' name='" . $var - . ".forminput' ".qq{id="$id"}." value='" . HTML::Entities::encode($fileName,"<>&\"'"). + . "_forminput' ".qq{id="$id"}." value='" . HTML::Entities::encode($fileName,"<>&\"'"). "'"; if (!$self->{'multichoice'} && $choices == 0) { $result .= ' checked="checked"'; @@ -3092,7 +2838,7 @@ sub fileState { sub postprocess { my $self = shift; - my $result = $env{'form.' . $self->{'variable'} . '.forminput'}; + my $result = $env{'form.' . $self->{'variable'} . '_forminput'}; if (!$result) { $self->{ERROR_MSG} = 'You must choose at least one file '. 'to continue.'; @@ -3182,7 +2928,7 @@ sub start_section { return if ($token->[2]{'onlysections'}); # add in groups to the end of the list - my %curr_groups = &Apache::loncommon::coursegroups(); + my %curr_groups = &Apache::longroup::coursegroups(); foreach my $group_name (sort(keys(%curr_groups))) { push(@{$paramHash->{CHOICES}}, [$group_name, $group_name]); } @@ -3246,7 +2992,7 @@ sub start_group { # Populate the CHOICES element my %choices; - my %curr_groups = &Apache::loncommon::coursegroups(); + my %curr_groups = &Apache::longroup::coursegroups(); foreach my $group_name (sort {lc($a) cmp lc($b)} (keys(%curr_groups))) { push(@{$paramHash->{CHOICES}}, [$group_name, $group_name]); } @@ -3328,7 +3074,7 @@ sub render { $result .= '<p><font color="#FF0000">' . $self->{ERROR_MSG} . '</font></p>'; } - $result .= '<input type="string" name="' . $self->{'variable'} . '.forminput"'; + $result .= '<input type="string" name="' . $self->{'variable'} . '_forminput"'; if (defined($self->{'size'})) { $result .= ' size="' . $self->{'size'} . '"'; @@ -3461,7 +3207,8 @@ sub start_clause { die 'Error in clause of condition, Perl said: ' . $@ if $@; if (!&$clause($helper, $paramHash)) { # Discard all text until the /condition. - &Apache::lonxml::get_all_text('/condition', $parser); + my $end_tag = $paramHash->{SKIPTAG} || '/condition'; + &Apache::lonxml::get_all_text($end_tag, $parser); } } @@ -3734,8 +3481,10 @@ sub render { if ($vars->{GRANULARITY} eq 'whole_course') { $resourceString .= '<li>'.&mt('for <b>all resources in the course</b>').'</li>'; if ($vars->{TARGETS} eq 'course') { - $level = 11; # general course, see lonparmset.pm perldoc + $level = 14; # general course, see lonparmset.pm perldoc } elsif ($vars->{TARGETS} eq 'section') { + $level = 9; + } elsif ($vars->{TARGETS} eq 'group') { $level = 6; } else { $level = 3; @@ -3750,8 +3499,10 @@ sub render { $symb = $res->symb(); $resourceString .= '<li>'.&mt('for the map named [_1]',"<b>$title</b>").'</li>'; if ($vars->{TARGETS} eq 'course') { - $level = 10; # general course, see lonparmset.pm perldoc + $level = 13; # general course, see lonparmset.pm perldoc } elsif ($vars->{TARGETS} eq 'section') { + $level = 8; + } elsif ($vars->{TARGETS} eq 'group') { $level = 5; } else { $level = 2; @@ -3767,8 +3518,10 @@ sub render { my $title = $res->compTitle(); $resourceString .= '<li>'.&mt('for the resource named [_1] part [_2]',"<b>$title</b>","<b>$part</b>").'</li>'; if ($vars->{TARGETS} eq 'course') { - $level = 7; # general course, see lonparmset.pm perldoc + $level = 10; # general course, see lonparmset.pm perldoc } elsif ($vars->{TARGETS} eq 'section') { + $level = 7; + } elsif ($vars->{TARGETS} eq 'group') { $level = 4; } else { $level = 1;