Diff for /loncom/homework/lonhomework.pm between versions 1.359 and 1.360

version 1.359, 2015/10/26 20:36:45 version 1.360, 2016/03/15 14:25:33
Line 1172  sub editxmlmode { Line 1172  sub editxmlmode {
 #    Render the page in whatever target desired.  #    Render the page in whatever target desired.
 #  #
 sub renderpage {  sub renderpage {
     my ($request,$file,$targets,$return_string) = @_;      my ($request,$file,$targets,$return_string,$donebuttonmsg) = @_;
   
     my @targets = @{$targets || [&get_target()]};      my @targets = @{$targets || [&get_target()]};
     &Apache::lonhomework::showhashsubset(\%env,'form.');      &Apache::lonhomework::showhashsubset(\%env,'form.');
Line 1225  sub renderpage { Line 1225  sub renderpage {
     if ($target eq 'analyze') {      if ($target eq 'analyze') {
  $result=&Apache::lonnet::hashref2str(\%Apache::lonhomework::analyze);   $result=&Apache::lonnet::hashref2str(\%Apache::lonhomework::analyze);
  undef(%Apache::lonhomework::analyze);   undef(%Apache::lonhomework::analyze);
     }      } elsif ($target eq 'web') {
                   if ($donebuttonmsg) {
                       $result =~ s{</body>}{};
                       $result.= &Apache::loncommon::confirmwrapper(&Apache::lonhtmlcommon::confirm_success($donebuttonmsg,1))."\n</body>";
                   }
               }
     #my $td=&tv_interval($t0);      #my $td=&tv_interval($t0);
     #if ( $Apache::lonxml::debug) {      #if ( $Apache::lonxml::debug) {
     #$result =~ s:</body>::;      #$result =~ s:</body>::;
Line 1430  sub zero_timer { Line 1435  sub zero_timer {
     my @interval=&Apache::lonnet::EXT("resource.0.interval",$symb);      my @interval=&Apache::lonnet::EXT("resource.0.interval",$symb);
     if (@interval > 1) {      if (@interval > 1) {
         if ($interval[1] eq 'course') {          if ($interval[1] eq 'course') {
             return;              return ('fail',&mt('Ending of timed events not supported for intervals set course-wide'));
         } else {          } else {
             my $now = time;              my $now = time;
             my $first_access=&Apache::lonnet::get_first_access($interval[1],$symb);              my $first_access=&Apache::lonnet::get_first_access($interval[1],$symb);
             if ($first_access > 0) {              if ($first_access > 0) {
                 my ($timelimit) = split(/_/,$interval[0]);                  my ($timelimit,$done,$proctor,$secret) = split(/_/,$interval[0]);
                 if ($first_access+$timelimit > $now) {                  if ($done eq 'done') { 
                     my $done_time = $now - $first_access;                      if (($proctor) && ($secret ne '')) {
                     my $snum = 1;                          my $key = $env{'form.LC_interval_done_proctorpass'};
                     if ($interval[1] eq 'map') {                          $key =~ s/^\s+//;
                         $snum = 2;                          $key =~ s/\s+$//;
                           if ($env{'form.LC_interval_done_proctorpass'} ne $secret) {
                               return ('fail',
                                      &mt('Incorrect key entered by proctor')); 
                           }
                     }                      }
                     my $result =                       if ($first_access+$timelimit > $now) {
                         &Apache::lonparmset::storeparm_by_symb_inner($symb,'0_interval',                          my $done_time = $now - $first_access;
                                                                      $snum,$done_time,                          my $snum = 1;
                                                                      'date_interval',                          if ($interval[1] eq 'map') {
                                                                      $env{'user.name'},                              $snum = 2;
                                                                      $env{'user.domain'});                          }
                         # Record action in "User Notes"                          my $result =
                         &Apache::lonmsg::store_instructor_comment(                              &Apache::lonparmset::storeparm_by_symb_inner($symb,'0_interval',
                             'Pressed Done button for symb:<br />'.$symb,                                                                           $snum,$done_time,
                             $env{'user.name'}, $env{'user.domain'});                                                                           'date_interval',
                     return $result;                                                                           $env{'user.name'},
                                                                            $env{'user.domain'});
                           if ($result eq '') {
                               # Record action in "User Notes"
                               &Apache::lonmsg::store_instructor_comment(
                                   'Pressed Done button for symb:<br />'.$symb,
                                   $env{'user.name'}, $env{'user.domain'});
                               return ('ok');
                           } else {
                               return ('fail',&mt('Error ending timed event: [_1]',$result));
                           } 
                       } else {
                           return ('fail',&mt('Timed event already ended'));
                       }
                   } else {
                       return ('fail',&mt('Timed event can not be ended before the time limit'));
                 }                  }
               } else {
                   return ('fail',&mt('Timer not yet started for this timed event'));
             }              }
         }          }
       } else {
           return ('fail',&mt('No timer in use'));
     }      }
     return;      return();
 }  }
   
 sub handler {  sub handler {
Line 1519  sub handler { Line 1547  sub handler {
     } else {      } else {
         # Set the event timer to zero if the "done button" was clicked.  The button is          # Set the event timer to zero if the "done button" was clicked.  The button is
         # part of the doneButton form created in lonmenu.pm          # part of the doneButton form created in lonmenu.pm
           my ($donebuttonresult,$donemsg);
         if ($symb && $env{'form.LC_interval_done'} eq 'true') {            if ($symb && $env{'form.LC_interval_done'} eq 'true') {  
             &zero_timer($symb);              ($donebuttonresult,$donemsg) = &zero_timer($symb);
             undef($env{'form.LC_interval_done'});              undef($env{'form.LC_interval_done'});
               undef($env{'form.LC_interval_done_proctorpass'});
         }          }
  # just render the page normally outside of construction space   # just render the page normally outside of construction space
  &Apache::lonxml::debug("not construct");   &Apache::lonxml::debug("not construct");
  &renderpage($request,$file);   &renderpage($request,$file,undef,undef,$donemsg);
     }      }
     #my $td=&tv_interval($t0);      #my $td=&tv_interval($t0);
     #&Apache::lonxml::debug("Spent $td seconds processing");      #&Apache::lonxml::debug("Spent $td seconds processing");

Removed from v.1.359  
changed lines
  Added in v.1.360


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