--- loncom/homework/bridgetask.pm 2007/02/22 21:40:40 1.226 +++ loncom/homework/bridgetask.pm 2009/03/27 01:07:10 1.247 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # definition of tags that give a structure to a document # -# $Id: bridgetask.pm,v 1.226 2007/02/22 21:40:40 albertel Exp $ +# $Id: bridgetask.pm,v 1.247 2009/03/27 01:07:10 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -38,7 +38,6 @@ use Apache::lonlocal; use Apache::lonxml; use Apache::slotrequest(); use Time::HiRes qw( gettimeofday tv_interval ); -use lib '/home/httpd/lib/perl/'; use LONCAPA; @@ -83,7 +82,10 @@ sub proctor_check_auth { } } if ($authenticated) { - &check_in($type,$user,$domain,$slot_name); + my $check = &check_in($type,$user,$domain,$slot_name); + if ($check =~ /^error:/) { + return 0; + } return 1; } } @@ -95,7 +97,10 @@ sub check_in { my ($type,$user,$domain,$slot_name) = @_; my $useslots = &Apache::lonnet::EXT("resource.0.useslots"); if ( $useslots eq 'map_map') { - &check_in_sequence($user,$domain,$slot_name); + my $result = &check_in_sequence($user,$domain,$slot_name); + if ($result =~ /^error: /) { + return $result; + } } else { &create_new_version($type,$user,$domain,$slot_name); &Apache::structuretags::finalize_storage(); @@ -106,6 +111,9 @@ sub check_in { sub check_in_sequence { my ($user,$domain,$slot_name) = @_; my $navmap = Apache::lonnavmaps::navmap->new(); + if (!defined($navmap)) { + return 'error: '; + } my ($symb) = &Apache::lonnet::whichuser(); my ($map) = &Apache::lonnet::decode_symb($symb); my @resources = @@ -245,11 +253,20 @@ sub add_grading_button { my $result="\n\t".'<input type="submit" name="gradeasubmission" value="'. &mt("Get a submission to grade").'" />'; $result.="\n\t".'<input type="hidden" name="grade_target" value="webgrade" />'; - if (&Apache::lonnet::allowed('mgq',$env{'request.course.id'})) { + my $see_all = &Apache::lonnet::allowed('mgq',$env{'request.course.id'}); + my $see_sec = &Apache::lonnet::allowed('mgq',$env{'request.course.id'}. + '/'.$env{'request.course.sec'}); + + if ($see_all || $see_sec) { my ($entries,$ready,$locks)=&get_queue_counts('gradingqueue'); $result.="\n\t".'<table>'."\n\t\t".'<tr>'; - $result.="\n\t\t\t".'<td rowspan="4">Specify a section: </td>'. - "\n\t\t\t".'<td rowspan="4">'.$sec_select."\n\t\t\t".'</td>'; + if ($see_all || (!§ion_restricted())) { + $result.="\n\t\t\t".'<td rowspan="4">'.&mt('Specify a section:').' </td>'. + "\n\t\t\t".'<td rowspan="4">'.$sec_select."\n\t\t\t".'</td>'; + } else { + $result.="\n\t\t\t".'<td rowspan="4">'.&mt('Grading section:').' </td>'. + "\n\t\t\t".'<td rowspan="4">'.$env{'request.course.sec'}."\n\t\t\t".'</td>'; + } $result.="\n\t\t\t".'<td>'.'<input type="submit" name="reviewagrading" value="'. &mt("Select an entry from the grading queue:").'" /> '; @@ -286,7 +303,7 @@ sub add_grading_button { sub add_request_another_attempt_button { my ($text)=@_; - if (!$text) { $text="Request another attempt"; } + if (!$text) { $text=&mt('Request another attempt'); } my $result; my $symb=&Apache::lonnet::symbread(); # not a slot access based resource @@ -298,13 +315,14 @@ sub add_request_another_attempt_button { my ($slot_name,$slot)=&Apache::slotrequest::check_for_reservation($symb); my $action='get_reservation'; if ($slot_name) { - $text="Change reservation."; + $text=&mt('Change reservation'); $action='change_reservation'; my $description=&Apache::slotrequest::get_description($slot_name, $slot); - $result.=(<<STUFF); - <p> Will be next available: $description </p> -STUFF + $result.='<p>' + .&mt('Will be next available:') + .' '.$description + .'</p>'; } if ($env{'request.enc'}) { $symb=&Apache::lonenc::encrypted($symb); } @@ -314,7 +332,7 @@ STUFF '<input type="hidden" name="symb" value="'.$symb.'" />'."\n\t\t". '<input type="hidden" name="command" value="'.$action.'" />'."\n\t\t". '<input type="submit" name="requestattempt" value="'. - &mt($text).'" />'."\n\t". + $text.'" />'."\n\t". '</form>'."\n"; return $result; } @@ -464,7 +482,7 @@ sub file_list { my $file=$file_url.$partial_file; $file=~s|/+|/|g; &Apache::lonnet::allowuploaded('/adm/bridgetask',$file); - $file_list.='<li><span style="white-space: nowrap;"><a href="'.$file.'?rawmode=1" target="lonGRDs"><img src="'. + $file_list.='<li><span class="LC_nobreak"><a href="'.$file.'?rawmode=1" target="lonGRDs"><img src="'. &Apache::loncommon::icon($file).'" alt="file icon" border="0" /> '.$file. '</a></span></li>'."\n"; } @@ -484,37 +502,47 @@ sub webgrade_standard_info { my $file_list = &file_list($Apache::lonhomework::history{"resource.$version.0.bridgetask.portfiles"}); - my %lt=('done' => 'Next Item', - 'stop' => 'Quit Grading', - 'fail' => 'Fail Rest', - 'cancel' => 'Cancel', - ); - %lt=&Apache::lonlocal::texthash(%lt); + my %lt = &Apache::lonlocal::texthash( + 'done' => 'Next Item', + 'stop' => 'Quit Grading', + 'fail' => 'Fail Rest', + 'cancel' => 'Cancel', + 'submit' => 'Submit Grades', + ); my $result=<<INFO; <div class="LC_GRADING_maincontrols"> INFO - if (&grade_mode() eq 'regrade') { + if ($env{'request.state'} eq 'construct') { $result.=<<INFO; + <input type="submit" name="next" value="$lt{'submit'}" /> +INFO + } else { + if (&grade_mode() eq 'regrade' && $env{'request.state'} ne 'construct') { + $result.=<<INFO; <input type="submit" name="cancel" value="$lt{'cancel'}" /> INFO - } + } - $result.=<<INFO; + $result.=<<INFO; <input type="submit" name="next" value="$lt{'done'}" /> <input type="submit" name="stop" value="$lt{'stop'}" /> +INFO + } + $result.=<<INFO; <input type="button" name="fail" value="$lt{'fail'}" onclick="javascript:onFailRest()" /> </div> $file_list INFO return $result; + } sub done_screen { my ($version) = @_; - my $title=&Apache::lonnet::gettitle(); + my $title=&Apache::lonnet::gettitle($env{'request.uri'}); my @files=split(',',$Apache::lonhomework::history{'resource.'.$version.'.0.bridgetask.portfiles'}); my (undef,undef,$domain,$user)= &Apache::lonnet::whichuser(); my $files = '<ul>'; @@ -522,17 +550,19 @@ sub done_screen { foreach my $file (@files) { my $url="/uploaded/$domain/$user/portfolio$file"; if (! &Apache::lonnet::stat_file($url)) { - $file = &mt('<span class="LC_error"> Nonexistent file:</span> '. - '<span class="LC_filename">[_1]</span>',$file); - $msg .= "<p>Submitted non-existant file $file</p>\n"; + $file = '<span class="LC_error">' + .&mt('[_1]Nonexistent file:[_2]' + ,'<span class="LC_error"> ' + ,'</span> <span class="LC_filename">'.$file.'</span>'); + $msg .= "<p>".&mt('Submitted non-existent file [_1]',$file)."</p>\n"; } else { $file = '<span class="LC_filename">'.$file.'</span>'; - $msg .= "<p>Submitted file $file</p>\n"; + $msg .= "<p>".&mt('Submitted file [_1]',$file)."</p>\n"; } $files .= '<li>'.$file.'</li>'; } $files.='</ul>'; - my $subject = "Submission message for $title"; + my $subject = &mt('Submission message for [_1]',$title); my ($message_status,$comment_status); my $setting = $env{'course.'.$env{'request.course.id'}.'.task_messages'}; $setting =~ s/^\s*(\S*)\s*$/$1/; @@ -551,16 +581,14 @@ sub done_screen { $comment_status = '<p>'.&mt('Message sent to instructor: [_1]', $comment_status).' </p>'; } - return <<DONESCREEN; -<h2>$title</h2> -<p> Files submitted: $files </p> -<p> You are now done with this Bridge Task </p> -<hr /> -<p> <a href="/adm/logout">Logout</a> </p> -<p> <a href="/adm/roles">Change to a different course</a> </p> -$message_status -$comment_status -DONESCREEN + return "<h2>$title</h2>" + .'<p>'.&mt('Files submitted: [_1]',$files).'</p>' + .'<p>'.&mt('You are now done with this Bridge Task').'</p>' + .'<hr />' + .'<p><a href="/adm/logout">'.&mt('Logout').'</a></p>' +.'<p><a href="/adm/roles">'.&mt('Change to a different course').'</a></p>' +.$message_status +.$comment_status; } @@ -601,7 +629,8 @@ sub start_Task { if ($env{'request.enc'}) { $uri=&Apache::lonenc::encrypted($uri); } $result.=$uri.'">'.&add_grading_button()."</form>\n"; my $symb=&Apache::lonnet::symbread(); - if (&Apache::lonnet::allowed('mgq',$env{'request.course.id'})) { + if (&Apache::lonnet::allowed('mgq',$env{'request.course.id'}) + || &Apache::lonnet::allowed('mgq',$env{'request.course.id'}.'/'.$env{'request.course.sec'})) { $result.='<form method="post" name="slotrequest" action="/adm/slotrequest">'. '<input type="hidden" name="symb" value="'.$symb.'" />'. '<input type="hidden" name="command" value="showslots" />'. @@ -611,16 +640,18 @@ sub start_Task { my $target_id = &Apache::lonstathelpers::make_target_id({symb => $symb, part => '0'}); - $result.='<form method="post" name="gradingstatus" action="/adm/statistics">'. - '<input type="hidden" name="problemchoice" value="'.$target_id.'" />'. - '<input type="hidden" name="reportSelected" value="grading_analysis" />'. - '<input type="submit" name="grading" value="'. - &mt('Show Grading Status').'" />'. - '</form>'; + if (!§ion_restricted()) { + $result.='<form method="post" name="gradingstatus" action="/adm/statistics">'. + '<input type="hidden" name="problemchoice" value="'.$target_id.'" />'. + '<input type="hidden" name="reportSelected" value="grading_analysis" />'. + '<input type="submit" name="grading" value="'. + &mt('Show Grading Status').'" />'. + '</form>'; + } } } } - if ($target eq 'web' && $env{'request.state'} eq 'construct') { + if ($target =~/(web|webgrade)/ && $env{'request.state'} eq 'construct') { $form_tag_start.=&Apache::structuretags::problem_web_to_edit_header($env{'form.rndseed'}); } if ($target eq 'web' @@ -633,7 +664,11 @@ sub start_Task { if ($status eq 'CAN_ANSWER' && $version eq '') { # CAN_ANSWER mode, and no current version, unproctored access # thus self-checkedin - &check_in('Task',undef,undef,$slot_name); + my $check = &check_in('Task',undef,undef,$slot_name); + if ($check =~ /^error: /) { + my $symb=&Apache::lonnet::symbread(); + &Apache::lonnet::logthis("Error during self-checkin of version $version of Task (symb: $symb) using slot: $slot_name"); + } &add_to_queue('gradingqueue',{'type' => 'Task', 'time' => time, 'slot' => $slot_name}); @@ -663,7 +698,7 @@ sub start_Task { $msg.='<h1>'.&mt('Unable to determine if this resource is open due to network problems. Please try again later.').'</h1>'; } elsif ($status eq 'NOT_IN_A_SLOT') { $msg.='<h1>'.&mt('You are not currently signed up to work at this time and/or place.').'</h1>'; - $msg.=&add_request_another_attempt_button("Sign up for time to work."); + $msg.=&add_request_another_attempt_button("Sign up for time to work"); } elsif ($status eq 'NEEDS_CHECKIN') { $msg.='<h1>'.&mt('You need the Proctor to validate you.'). '</h1>'.&proctor_validation_screen($slot); @@ -724,8 +759,12 @@ sub start_Task { if ($todo) { &setup_env_for_other_user($todo,$safeeval); my ($symb,$uname,$udom)=&decode_queue_key($todo); - $result.="\n".'<table><tr><td>Found '. - &Apache::lonnet::gettitle($symb).' for '.$uname.' at '.$udom.'</td></tr></table>'; + if ($env{'request.state'} eq 'construct') { + $symb = $env{'request.uri'}; + } + $result.="\n".'<p>'. + &mt('Grading [_1] for [_2] at [_3]', + &Apache::lonnet::gettitle($symb),$uname,$udom).'</p>'; $form_tag_start.= '<input type="hidden" name="gradingkey" value="'. &escape($todo).'" />'; @@ -791,15 +830,20 @@ sub start_Task { $result.='<input type="hidden" name="regrade" value="'. $env{'form.regrade'}.'" />'; } - if ($env{'form.chosensections'}) { - my @chosen_sections= - &Apache::loncommon::get_env_multiple('form.chosensections'); + if ($env{'form.chosensections'} || §ion_restricted()) { + my @chosen_sections = &get_allowed_sections(); foreach my $sec (@chosen_sections) { $result.='<input type="hidden" name="chosensections" value="'.$sec.'" />'; } } if ($webgrade eq 'yes') { $result.=&webgrade_standard_info(); } + } elsif ($target eq 'webgrade' + && $env{'request.state'} eq 'construct') { + $result.=$form_tag_start; + $result.='<input type="hidden" name="webgrade" value="'. + $webgrade.'" />'; + $result.=&webgrade_standard_info(); } if ($target eq 'webgrade') { $result.="\n".'<div id="LC_GRADING_criterialist">'; @@ -847,6 +891,12 @@ sub get_key_todo { my ($target)=@_; my $todo; + if ($env{'request.state'} eq 'construct') { + my ($symb,$cid,$udom,$uname) = &Apache::lonnet::whichuser(); + my $gradingkey=&encode_queue_key($symb,$udom,$uname); + return ($gradingkey); + } + if (defined($env{'form.reviewasubmission'})) { &Apache::lonxml::debug("review a submission...."); $env{'form.queue'}='reviewqueue'; @@ -877,7 +927,14 @@ sub get_key_todo { my $cdom = $env{'course.'.$cid.'.domain'}; my $uname = &LONCAPA::clean_username($env{'form.gradinguser'}); my $udom = &LONCAPA::clean_domain($env{'form.gradingdomain'}); - + + if (§ion_restricted()) { + my $classlist=&get_limited_classlist(); + if (!&allow_grade_user($classlist->{$uname.':'.$udom})) { + return (undef,'not_allowed', + &mt('Requested student ([_1]) is in a section you aren\'t allowed to grade.',$uname.':'.$udom)); + } + } my $gradingkey=&encode_queue_key($symb,$udom,$uname); my $queue; @@ -1039,7 +1096,7 @@ sub end_Task { } if (!$previous && $status ne 'SHOW_ANSWER' && &show_task($status,$previous)) { - $result.=&Apache::inputtags::gradestatus('0'); + $result.=&Apache::inputtags::gradestatus('0',$target,1); } $result.='</form>'; @@ -1047,18 +1104,18 @@ sub end_Task { if (!$previous && $status ne 'SHOW_ANSWER' && &show_task($status,$previous)) { my $action = &Apache::lonenc::check_encrypt($env{'request.uri'}); + my $donetext = &mt('Done'); $result.=<<DONEBUTTON; <form name="done" method="post" action="$action"> <input type="hidden" name="donescreen" value="1" /> - <input type="submit" value="Done" /> + <input type="submit" value="$donetext" /> </form> DONEBUTTON } if (&show_task($status,$previous) && $Apache::lonhomework::history{"resource.$version.0.status"} =~ /^(pass|fail)$/) { my $bt_status=$Apache::lonhomework::history{"resource.$version.0.status"}; - my $title=&Apache::lonnet::gettitle(); - + my $title=&Apache::lonnet::gettitle($env{'request.uri'}); my $start_time; my $slot_name= @@ -1084,13 +1141,15 @@ DONEBUTTON "</p>\n"; if ($bt_status eq 'pass') { - $status.='<h2>You passed the '.$title.' given on '. - $start_time.'</h2>'; + $status.='<h2>' + .&mt('You passed the [_1] given on [_2].',$title,$start_time) + .'</h2>'; $status.=$question_status; } if ($bt_status eq 'fail') { - $status.='<h2>You did not pass the '.$title.' given on '. - $start_time.'</h2>'; + $status.='<h2>' + .&mt('You did not pass the [_1] given on [_2].',$title,$start_time) + .'</h2>'; $status.=$question_status; if (!$previous) { $status.=&add_request_another_attempt_button(); @@ -1280,7 +1339,7 @@ DONEBUTTON } } if (exists($Apache::lonhomework::results{'INTERNAL_store'})) { - # instance generation occured and hasn't yet been stored + # instance generation occurred and hasn't yet been stored &Apache::structuretags::finalize_storage(); } } elsif ($target eq 'webgrade') { @@ -1332,9 +1391,7 @@ DONEBUTTON $result.=&Apache::response::meta_stores_write('status','string', 'Bridge Task Status'); } elsif ($target eq 'edit') { - &Apache::structuretags::reset_problem_globals('Task'); - undef($Apache::lonhomework::parsing_a_task); - return ('','no'); + $result.= &Apache::structuretags::problem_edit_footer(); } &Apache::structuretags::reset_problem_globals('Task'); undef($Apache::lonhomework::parsing_a_task); @@ -1496,11 +1553,11 @@ sub get_limited_classlist { } } - if (ref($sections) && !grep('all',@{ $sections })) { + if (ref($sections) && !grep {$_ eq 'all'} (@{ $sections })) { foreach my $student (keys(%$classlist)) { my $section = $classlist->{$student}[&Apache::loncoursedata::CL_SECTION()]; - if (! grep($section,@{ $sections })) { + if (! grep {$_ eq $section} (@{ $sections })) { delete($classlist->{$student}); } } @@ -1516,14 +1573,15 @@ sub show_queue { my $cnum=$env{'course.'.$cid.'.num'}; my $cdom=$env{'course.'.$cid.'.domain'}; - my @chosen_sections= - &Apache::loncommon::get_env_multiple('form.chosensections'); + my @chosen_sections = &get_allowed_sections(); my $classlist = &get_limited_classlist(\@chosen_sections); if (!(grep(/^all$/,@chosen_sections))) { - $result.='<p> Showing only sections <tt>'.join(', ',@chosen_sections). - '</tt>.</p> '."\n"; + $result.='<p>' + .&mt('Showing only sections [_1].' + ,'<tt>'.join(', ',@chosen_sections).'</tt>') + ."</p>\n"; } my ($view,$view_section); @@ -1537,27 +1595,33 @@ sub show_queue { } } + $result .= + '<p><a href="/adm/flip?postdata=return:">'. + &mt('Return to resource').'</a></p><hr />'. + "\n<h3>".&mt('Current Queue - [_1]',$queue)."</h3>"; my $regexp="^$symb\0"; my %queue=&Apache::lonnet::dump($queue,$cdom,$cnum,$regexp); my ($tmp)=%queue; if ($tmp=~/^error: 2 /) { - return "\n<h3>Current Queue - $queue</h3>". + $result.= &Apache::loncommon::start_data_table(). &Apache::loncommon::start_data_table_row(). '<td>'.&mt('Empty').'</td>'. &Apache::loncommon::end_data_table_row(). &Apache::loncommon::end_data_table(); + return $result; } my $title=&Apache::lonnet::gettitle($symb); - $result.="\n<h3>Current Queue - $title $queue </h3>". + $result.= &Apache::loncommon::start_data_table(). &Apache::loncommon::start_data_table_header_row(); - if ($with_selects) { $result.="<th>Status</th><th></th>"; } - $result.="<th>user</th><th>data</th>". + if ($with_selects) { $result.='<th>'.&mt('Status').'</th><th></th>'; } + $result.='<th>'.&mt('User').'</th><th>'.&mt('Data').'</th>'. &Apache::loncommon::end_data_table_header_row(); foreach my $key (sort(keys(%queue))) { my ($symb,$uname,$udom) = &decode_queue_key($key); - if (!defined($classlist->{$uname.':'.$udom})) { next; } + next if (!defined($classlist->{$uname.':'.$udom})); + next if (!&allow_grade_user($classlist->{$uname.':'.$udom})); my $section = $classlist->{$uname.':'.$udom}[&Apache::loncoursedata::CL_SECTION()]; @@ -1599,7 +1663,7 @@ sub show_queue { 'start'); } my $me=$env{'user.name'}.':'.$env{'user.domain'}; - $status=&mt('Locked by <tt>[_1]</tt> [_2]',$locker,$time); + $status=&mt('Locked by [_1] [_2]','<tt>'.$locker.'</tt>',$time); if ($me eq $locker) { ($action,$description)=('resume',&mt('Resume')); } else { @@ -1634,15 +1698,46 @@ FORM } $result.= "<td>".$classlist->{$uname.':'.$udom}[&Apache::loncoursedata::CL_FULLNAME()]. " <tt>($uname:$udom)</tt> </td>"; - $result.='<td>'.$slot_text.' End time: '. - &Apache::lonlocal::locallocaltime($end_time). - "</td>".&Apache::loncommon::end_data_table_row(); + $result.='<td>'.$slot_text.' ' + .&mt('End time: [_1]' + ,&Apache::lonlocal::locallocaltime($end_time)) + .'</td>' + .&Apache::loncommon::end_data_table_row(); } } $result.= &Apache::loncommon::end_data_table()."<hr />\n"; return $result; } +sub get_allowed_sections { + my @chosen_sections; + if (§ion_restricted()) { + @chosen_sections = ($env{'request.course.sec'}); + } else { + @chosen_sections = + &Apache::loncommon::get_env_multiple('form.chosensections'); + } + + return @chosen_sections; +} + +sub section_restricted { + my $cid =(&Apache::lonnet::whichuser())[1]; + return (lc($env{'course.'.$cid.'.task_grading'}) eq 'section' + && $env{'request.course.sec'} ne '' ); +} + +sub allow_grade_user { + my ($classlist_entry) = @_; + + if (§ion_restricted() + && $env{'request.course.sec'} ne + $classlist_entry->[&Apache::loncoursedata::CL_SECTION()]) { + return 0; + } + return 1; +} + sub get_queue_counts { my ($queue)=@_; my $result; @@ -1658,11 +1753,14 @@ sub get_queue_counts { if ($tmp=~/^error: 2 /) { return (0,0,0); } + my ($entries,$ready_to_grade,$locks)=(0,0,0); my %slot_cache; foreach my $key (sort(keys(%queue))) { my ($symb,$uname,$udom) = &decode_queue_key($key); - if (!defined($classlist->{$uname.':'.$udom})) { next; } + next if (!defined($classlist->{$uname.':'.$udom})); + next if (!&allow_grade_user($classlist->{$uname.':'.$udom})); + if ($key=~/locked$/) { $locks++; } elsif ($key=~/timestamp$/) { @@ -1739,7 +1837,8 @@ sub pick_from_queue_data { if ($key =~ /\0timestamp$/) { next; } my ($symb,$uname,$udom)=&decode_queue_key($key); - if (!defined($classlist->{$uname.':'.$udom})) { next; } + next if (!defined($classlist->{$uname.':'.$udom})); + next if (!&allow_grade_user($classlist->{$uname.':'.$udom})); if ($check_section) { my $section = @@ -1848,7 +1947,7 @@ sub lock_key { sub get_queue_symb_status { my ($queue,$symb,$cdom,$cnum) = @_; if (!defined($cdom) || !defined($cnum)) { - my (undef,$cid)=&Apache::lonnet::whichuser(); + my (undef,$cid) =&Apache::lonnet::whichuser(); $cnum=$env{'course.'.$cid.'.num'}; $cdom=$env{'course.'.$cid.'.domain'}; } @@ -1864,6 +1963,7 @@ sub get_queue_symb_status { next if ($key=~/timestamp$/); my ($symb,$uname,$udom) = &decode_queue_key($key); next if (!defined($classlist->{$uname.':'.$udom})); + next if (!&allow_grade_user($classlist->{$uname.':'.$udom})); push(@users,"$uname:$udom"); } return @users; @@ -1950,15 +2050,15 @@ sub get_from_queue { sub select_user { my ($symb,$cid)=&Apache::lonnet::whichuser(); - my @chosen_sections= - &Apache::loncommon::get_env_multiple('form.chosensections'); - + my @chosen_sections = &get_allowed_sections(); my $classlist = &get_limited_classlist(\@chosen_sections); my $result; if (!(grep(/^all$/,@chosen_sections))) { - $result.='<p> Showing only sections <tt>'.join(', ',@chosen_sections). - '</tt>.</p> '."\n"; + $result.='<p>' + .&mt('Showing only sections [_1].' + ,'<tt>'.join(', ',@chosen_sections).'</tt>') + .'</p> '."\n"; } $result.=&Apache::loncommon::start_data_table(); @@ -1994,6 +2094,7 @@ sub select_user { $seclist.='<input type="hidden" name="chosensections" value="'.$sec.'" />'; } + my $buttontext=&mt('Regrade'); $result.=&Apache::loncommon::start_data_table_row(); $result.=<<RESULT; <td> @@ -2002,10 +2103,10 @@ sub select_user { <input type="hidden" name="queue" value="$queue" /> <input type="hidden" name="webgrade" value="no" /> <input type="hidden" name="regrade" value="yes" /> - <input type="submit" name="submit" value="Regrade" /> + <input type="submit" name="submit" value="$buttontext" /> $seclist </form> - <td>$classlist->{$student}[&Apache::loncoursedata::CL_FULLNAME()] <tt>($student)</tt></td> + <td>$classlist->{$student}[&Apache::loncoursedata::CL_FULLNAME()] <tt>($student)</tt> Sec: $classlist->{$student}[&Apache::loncoursedata::CL_SECTION()]</td> <td> RESULT } @@ -2078,13 +2179,8 @@ sub start_ClosingParagraph { } elsif ($target eq 'webgrade') { &Apache::lonxml::startredirection(); } elsif ($target eq 'edit') { - my $bodytext=&Apache::lonxml::get_all_text("/closingparagraph", - $parser); $result = &Apache::edit::tag_start($target,$token); - $result.= &Apache::edit::editfield($token->[1],$bodytext,'',80,4); } elsif ($target eq 'modified') { - $result = $token->[4].&Apache::edit::modifiedfield('/closingparagraph', - $parser); } return $result; } @@ -2099,6 +2195,14 @@ sub end_ClosingParagraph { return $result; } +sub insert_ClosingParagraph { + return ' +<ClosingParagraph> + <startouttext /> + <endouttext /> +</ClosingParagraph>'; +} + sub get_dim_id { if (@Apache::bridgetask::dimension) { return $Apache::bridgetask::dimension[-1]; @@ -2109,9 +2213,7 @@ sub get_dim_id { sub get_id { my ($parstack,$safeeval)=@_; - my $id=&Apache::lonxml::get_param('id',$parstack,$safeeval); - if (!$id) { $id=$Apache::lonxml::curdepth; } - return $id; + return &Apache::lonxml::get_id($parstack,$safeeval); } sub start_Setup { @@ -2199,8 +2301,8 @@ sub start_Dimension { $result.= &Apache::edit::text_arg('Id:','id',$token,10).' '. &Apache::edit::select_arg('Passing is Mandatory:','Mandatory', - [['yes', 'Yes'], - ['no','No'],], + [['Y', 'Yes'], + ['N','No'],], $token).' <br /> '. &Apache::edit::text_arg('Required number of passed optional elements to pass the '.$token->[1].':', 'OptionalRequired',$token,4). @@ -2225,12 +2327,8 @@ sub start_QuestionText { my $dim = &get_dim_id(); $dimension{$dim}{'questiontext'}=$text; } elsif ($target eq 'edit') { - my $bodytext=&Apache::lonxml::get_all_text("/questiontext",$parser); $result = &Apache::edit::tag_start($target,$token); - $result.= &Apache::edit::editfield($token->[1],$bodytext,'',80,4); } elsif ($target eq 'modified') { - $result = $token->[4].&Apache::edit::modifiedfield('/questiontext', - $parser); } return $result; } @@ -2239,6 +2337,14 @@ sub end_QuestionText { return ''; } +sub insert_QuestionText { + return ' +<QuestionText> + <startouttext /> + <endouttext /> +</QuestionText>'; +} + sub get_instance { my ($dim)=@_; my $rand_alg=&Apache::lonnet::get_rand_alg(); @@ -2350,10 +2456,14 @@ sub end_Dimension { ('sub' x $dimension{$dim}{'depth'}).'question'; $ucquestion =~ s/^(.)/uc($1)/e; if ($dim_status eq 'pass') { - $dim_info.='<h3>'.$ucquestion.' : you passed this '.$mandatory.' '.$question.'</h3>'; + $dim_info.='<h3>'.$ucquestion.' : ' + .&mt('you passed this [_1] [_2]',$mandatory,$question) + .'</h3>'; } if ($dim_status eq 'fail') { - $dim_info.='<h3>'.$ucquestion.' : you did not pass this '.$mandatory.' '.$question.'</h3>'; + $dim_info.='<h3>'.$ucquestion.' : ' + .&mt('you did not pass this [_1] [_2]',$mandatory,$question) + .'</h3>'; } my %counts = &get_counts($dim,$instance,$parstack, $safeeval); @@ -2552,16 +2662,11 @@ sub question_status_message { } $status .= '.'; if ($counts->{'opt'}) { - $status .= ' You were required to pass '.$counts->{'opt_req'}. - ' optional '; - if ($counts->{'opt_dim'} + $counts->{'man_dim'} < 1) { - $status .= - ($counts->{'opt_req'} == 1?'criterion':'criteria'); - } else { - $status .= - 'component'.($counts->{'opt_req'} == 1?'':'s'); - } - $status .= '.'; + if ($counts->{'opt_dim'} + $counts->{'man_dim'} < 1) { + $status .= ' '.&mt('You were required to pass [quant,_1,optional criterion,optional criteria].',$counts->{'opt_req'}); + } else { + $status .= ' '.&mt('You were required to pass [quant,_1,optional component].',$counts->{'opt_req'}); + } } return $status; } @@ -2660,7 +2765,8 @@ sub end_Setup { sub grading_history { my ($version,$dim,$id) = @_; - if (!&Apache::lonnet::allowed('mgq',$env{'request.course.id'})) { + if (!&Apache::lonnet::allowed('mgq',$env{'request.course.id'}) + && !&Apache::lonnet::allowed('mgq',$env{'request.course.id'}.'/'.$env{'request.course.sec'})) { return ''; } my ($result,$grader); @@ -2707,12 +2813,8 @@ sub start_IntroParagraph { } } elsif ($target eq 'edit') { - my $bodytext=&Apache::lonxml::get_all_text("/introparagraph",$parser); $result = &Apache::edit::tag_start($target,$token); - $result.= &Apache::edit::editfield($token->[1],$bodytext,'',80,4); } elsif ($target eq 'modified') { - $result = $token->[4].&Apache::edit::modifiedfield('/introparagraph', - $parser); } return $result; } @@ -2724,6 +2826,14 @@ sub end_IntroParagraph { } } +sub insert_IntroParagraph { + return ' +<IntroParagraph> + <startouttext /> + <endouttext /> +</IntroParagraph>'; +} + sub start_Instance { my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; my $dim = &get_dim_id(); @@ -2780,12 +2890,8 @@ sub start_InstanceText { my $instance_id=$Apache::bridgetask::instance{$dim}[-1]; $dimension{$dim}{$instance_id.'.text'}=$text; } elsif ($target eq 'edit') { - my $bodytext=&Apache::lonxml::get_all_text("/instancetext",$parser); $result = &Apache::edit::tag_start($target,$token); - $result.= &Apache::edit::editfield($token->[1],$bodytext,'',80,4); } elsif ($target eq 'modified') { - $result = $token->[4].&Apache::edit::modifiedfield('/instancetext', - $parser); } return $result; } @@ -2794,6 +2900,14 @@ sub end_InstanceText { return ''; } +sub insert_InstanceText { + return ' +<InstanceText> + <startouttext /> + <endouttext /> +</InstanceText>'; +} + sub start_Criteria { my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; my $result = ''; @@ -2826,41 +2940,12 @@ sub start_Criteria { push(@{$dimension{$dim}{'criterias'}},$id); } } elsif ($target eq 'edit') { - if (0) { - $result = &Apache::edit::tag_start($target,$token); - my $text=&Apache::lonxml::get_all_text("/criteria",$parser); - &Apache::lonnet::logthis("get_all_text criteria \n$text"); - my $local_parser = HTML::LCParser->new(\$text); - $local_parser->xml_mode(1); - $local_parser->marked_sections(1); - while (1) { - my $criteria_text = - &Apache::lonxml::get_all_text('gradernote',$local_parser); - $result.= - &Apache::edit::editfield($token->[1],$criteria_text,'',80,4); - - # check for a <GraderNote> next might be end - my $token = $local_parser->get_token(); - # is the end - last if (!$token); - my $gradernote = &Apache::lonxml::get_all_text('/gradernote', - $local_parser); - # purge the end tag - my $token = $local_parser->get_token(); - $gradernote = '<GraderNote>'.$gradernote.'</GraderNote>'; - @Apache::scripttag::parser_env = @_; - $result .= - &Apache::edit::end_row().&Apache::edit::start_spanning_row(). - &Apache::scripttag::xmlparse($gradernote). - &Apache::edit::end_row().&Apache::edit::start_spanning_row(); - } - } $result .=&Apache::edit::tag_start($target,$token); $result.= &Apache::edit::text_arg('Id:','id',$token,10).' '. &Apache::edit::select_arg('Passing is Mandatory:','Mandatory', - [['yes', 'Yes'], - ['no','No'],], + [['Y', 'Yes'], + ['N','No'],], $token) .' <br /> '.&Apache::edit::end_row(). &Apache::edit::start_spanning_row(); @@ -2911,13 +2996,13 @@ sub layout_webgrade_Criteria { my $link=&link($id); my $version = &get_version(); my $status = &get_criteria('status',$version,$dim,$id); - my %lt = ( 'ungraded' => 'Ungraded', - 'fail' => 'Fail', - 'pass' => 'Pass', - 'review' => 'Review', - 'comment' => 'Additional Comment for Student', - ); - %lt = &Apache::lonlocal::texthash(%lt); + my %lt = &Apache::lonlocal::texthash( + 'ungraded' => 'Ungraded', + 'fail' => 'Fail', + 'pass' => 'Pass', + 'review' => 'Review', + 'comment' => 'Additional Comment for Student', + ); my $comment = &get_criteria('comment',$version,$dim,$id); $comment = &HTML::Entities::encode($comment,'<>"&'); my %checked; @@ -2960,6 +3045,15 @@ sub end_Criteria { } elsif ($target eq 'modified') { } } +sub insert_Criteria { + return ' +<Criteria> + <CriteriaText> + <startouttext /> + <endouttext /> + </CriteriaText> +</Criteria>'; +} sub start_CriteriaText { my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; @@ -2967,12 +3061,8 @@ sub start_CriteriaText { if ($target eq 'grade' || $target eq 'web' || $target eq 'webgrade') { } elsif ($target eq 'edit') { - my $bodytext=&Apache::lonxml::get_all_text("/criteriatext",$parser); $result = &Apache::edit::tag_start($target,$token); - $result.= &Apache::edit::editfield($token->[1],$bodytext,'',80,4); } elsif ($target eq 'modified') { - $result = $token->[4].&Apache::edit::modifiedfield('/criteriatext', - $parser); } return $result; } @@ -2981,6 +3071,14 @@ sub end_CriteriaText { return ''; } +sub insert_CriteriaText { + return ' +<CriteriaText> + <startouttext /> + <endouttext /> +</CriteriaText>'; +} + sub start_GraderNote { my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; my $result; @@ -2988,12 +3086,8 @@ sub start_GraderNote { $result = '<div class="LC_GRADING_gradernote"><b>'. &mt('Note to graders:').'</b>'; } elsif ($target eq 'edit') { - my $bodytext=&Apache::lonxml::get_all_text("/gradernote",$parser); $result = &Apache::edit::tag_start($target,$token); - $result.= &Apache::edit::editfield($token->[1],$bodytext,'',80,4); } elsif ($target eq 'modified') { - $result = $token->[4].&Apache::edit::modifiedfield('/gradernote', - $parser); } elsif ($target eq 'web' || $target eq 'grade') { my $note=&Apache::lonxml::get_all_text('/gradernote',$parser,$style); } @@ -3009,46 +3103,90 @@ sub end_GraderNote { return; } +sub insert_GraderNote { + return ' +<GraderNote> + <startouttext /> + <endouttext /> +</GraderNote>'; +} sub proctor_validation_screen { my ($slot) = @_; my (undef,undef,$domain,$user) = &Apache::lonnet::whichuser(); my $url=&Apache::lonnet::studentphoto($domain,$user,'jpg'); + if ($url ne '/adm/lonKaputt/lonlogo_broken.gif') { + $url = "<tr><td colspan=\"2\"><img src=\"$url\" /></td></tr>"; + } else { + undef($url); + } + my $name=&Apache::loncommon::plainname($user,$domain); my $msg; if ($env{'form.proctorpassword'}) { - $msg='<p><font color="red">'.&mt("Failed to authenticate the proctor.") - .'</font></p>'; + $msg.='<p><span class="LC_warning">' + .&mt("Failed to authenticate the proctor.") + .'</span></p>'; + } + + my $valid; + my @possible_proctors=split(",",$slot->{'proctor'}); + foreach my $proctor (@possible_proctors) { + if ($proctor =~ /$LONCAPA::username_re:$LONCAPA::domain_re/) { + $valid = 1; + last; + } + } + if (!$valid) { + $msg.='<p><span class="LC_error">' + .&mt("No valid proctors are defined.") + .'</span></p>'; } + if (!$env{'form.proctordomain'}) { $env{'form.proctordomain'}=$domain; } + my $uri = &Apache::lonenc::check_encrypt($env{'request.uri'}); + $uri = &HTML::Entities::encode($uri,'<>&"'); + my %lt = &Apache::lonlocal::texthash( + 'prva' => "Proctor Validation", + 'yoro' => "Your room's proctor needs to validate your access to this resource.", + 'prus' => "Proctor's Username:", + 'pasw' => "Password:", + 'prdo' => "Proctor's Domain:", + 'vali' => 'Validate', + 'stui' => "Student who should be logged in is:", + 'name' => "Name:", + 'sid' => "Student/Employee ID:", + 'unam' => "Username:", + ); my $result= (<<ENDCHECKOUT); -<h2>Proctor Validation</h2> - <p>Your room's proctor needs to validate your access to this resource.</p> +<h2>$lt{'prva'}</h2> + <p>$lt{'yoro'}</p> $msg -<form name="checkout" method="post" action="$env{'request.uri'}"> +<form name="checkout" method="post" action="$uri"> <input type="hidden" name="validate" value="yes" /> <input type="hidden" name="submitted" value="yes" /> <table> - <tr><td>Proctor's Username:</td><td><input type="string" name="proctorname" value="$env{'form.proctorname'}" /></td></tr> - <tr><td>Password:</td><td><input type="password" name="proctorpassword" value="" /></td></tr> - <tr><td>Proctor's Domain:</td><td><input type="string" name="proctordomain" value="$env{'form.proctordomain'}" /></td></tr> + <tr><td>$lt{'prus'}</td><td><input type="string" name="proctorname" value="$env{'form.proctorname'}" /></td></tr> + <tr><td>$lt{'pasw'}</td><td><input type="password" name="proctorpassword" value="" /></td></tr> + <tr><td>$lt{'prdo'}</td><td><input type="string" name="proctordomain" value="$env{'form.proctordomain'}" /></td></tr> </table> -<input type="submit" name="checkoutbutton" value="Validate" /><br /> +<input type="submit" name="checkoutbutton" value="$lt{'vali'}" /><br /> <table border="1"> <tr><td> <table> - <tr><td colspan="2">Student who should be logged in is:</td></tr> - <tr><td>Name:</td><td>$name</td></tr> - <tr><td>Student ID:</td><td>$env{'environment.id'}</td></tr> - <tr><td>Usename</td><td>$user:$domain</td></tr> - <tr><td colspan="2"><img src="$url" /></td></tr> + <tr><td colspan="2">$lt{'stui'}</td></tr> + <tr><td>$lt{'name'}</td><td>$name</td></tr> + <tr><td>$lt{'sid'}</td><td>$env{'environment.id'}</td></tr> + <tr><td>$lt{'unam'}</td><td>$user:$domain</td></tr> + $url </table> </tr></td> </table> </form> ENDCHECKOUT + return $result; }