Diff for /loncom/homework/grades.pm between versions 1.15 and 1.17

version 1.15, 2001/08/20 23:27:27 version 1.17, 2001/11/29 23:16:29
Line 1 Line 1
   # The LearningOnline Network with CAPA
 # The LON-CAPA Grading handler  # The LON-CAPA Grading handler
   #
   # $Id$
   #
   # Copyright Michigan State University Board of Trustees
   #
   # This file is part of the LearningOnline Network with CAPA (LON-CAPA).
   #
   # LON-CAPA is free software; you can redistribute it and/or modify
   # it under the terms of the GNU General Public License as published by
   # the Free Software Foundation; either version 2 of the License, or
   # (at your option) any later version.
   #
   # LON-CAPA is distributed in the hope that it will be useful,
   # but WITHOUT ANY WARRANTY; without even the implied warranty of
   # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   # GNU General Public License for more details.
   #
   # You should have received a copy of the GNU General Public License
   # along with LON-CAPA; if not, write to the Free Software
   # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
   #
   # /home/httpd/html/adm/gpl.txt
   #
   # http://www.lon-capa.org/
   #
 # 2/9,2/13 Guy Albertelli  # 2/9,2/13 Guy Albertelli
 # 6/8 Gerd Kortemeyer  # 6/8 Gerd Kortemeyer
 # 7/26 H.K. Ng  # 7/26 H.K. Ng
Line 18  sub moreinfo { Line 44  sub moreinfo {
   $request->print("Unable to process request: $reason");    $request->print("Unable to process request: $reason");
   if ( $Apache::grades::viewgrades eq 'F' ) {    if ( $Apache::grades::viewgrades eq 'F' ) {
     $request->print('<form action="/adm/grades" method="post">'."\n");      $request->print('<form action="/adm/grades" method="post">'."\n");
     $request->print('<input type="hidden" name="url" value="'.$ENV{'form.url'}.'"></input>'."\n");      if ($ENV{'form.url'}) {
     $request->print('<input type="hidden" name="command" value="'.$ENV{'form.command'}.'"></input>'."\n");        $request->print('<input type="hidden" name="url" value="'.$ENV{'form.url'}.'" />'."\n");
     $request->print("Student:".'<input type="text" name="student" value="'.$ENV{'form.student'}.'"></input>'."<br />\n");      }
     $request->print("Domain:".'<input type="text" name="domain" value="'.$ENV{'user.domain'}.'"></input>'."<br />\n");      if ($ENV{'form.symb'}) {
     $request->print('<input type="submit" name="submit" value="ReSubmit"></input>'."<br />\n");        $request->print('<input type="hidden" name="symb" value="'.$ENV{'form.symb'}.'" />'."\n");
       }
       $request->print('<input type="hidden" name="command" value="'.$ENV{'form.command'}.'" />'."\n");
       $request->print("Student:".'<input type="text" name="student" value="'.$ENV{'form.student'}.'" />'."<br />\n");
       $request->print("Domain:".'<input type="text" name="domain" value="'.$ENV{'user.domain'}.'" />'."<br />\n");
       $request->print('<input type="submit" name="submit" value="ReSubmit" />'."<br />\n");
     $request->print('</form>');      $request->print('</form>');
   }    }
   return '';    return '';
Line 48  sub listStudents { Line 79  sub listStudents {
       if ( $Apache::grades::viewgrades eq 'F' ) {        if ( $Apache::grades::viewgrades eq 'F' ) {
   $request->print('<form action="/adm/grades" method="post">'."\n");    $request->print('<form action="/adm/grades" method="post">'."\n");
   $request->print("$sname @nameparts\n");    $request->print("$sname @nameparts\n");
   $request->print('<input type="hidden" name="url" value="'.$ENV{'form.url'}.'"></input>'."\n");    if ($ENV{'form.url'}) {
   $request->print('<input type="hidden" name="command" value="'.$ENV{'form.command'}.'"></input>'."\n");      $request->print('<input type="hidden" name="url" value="'.$ENV{'form.url'}.'" />'."\n");
   $request->print('<input type="hidden" name="student" value="'.$sname.'"></input>'."\n");    }
   $request->print('<input type="hidden" name="domain" value="'.$sdom.'"></input>'."\n");    if ($ENV{'form.symb'}) {
   $request->print('<input type="submit" name="submit" value="View"></input>'."<br />\n");      $request->print('<input type="hidden" name="symb" value="'.$ENV{'form.symb'}.'" />'."\n");
     }
     $request->print('<input type="hidden" name="command" value="'.$ENV{'form.command'}.'" />'."\n");
     $request->print('<input type="hidden" name="student" value="'.$sname.'" />'."\n");
     $request->print('<input type="hidden" name="domain" value="'.$sdom.'" />'."\n");
     $request->print('<input type="submit" name="submit" value="View" />'."<br />\n");
   $request->print('</form>');    $request->print('</form>');
       }        }
   }    }
Line 211  sub submission { Line 247  sub submission {
 #  if ($ENV{'form.student'} eq '') { &listStudents($request); return ''; }  #  if ($ENV{'form.student'} eq '') { &listStudents($request); return ''; }
   my ($uname,$udom) = &finduser($ENV{'form.student'});    my ($uname,$udom) = &finduser($ENV{'form.student'});
   if ($uname eq '') { &moreinfo($request,"Unable to find student"); return ''; }    if ($uname eq '') { &moreinfo($request,"Unable to find student"); return ''; }
   my $symb=&Apache::lonnet::symbread($url);    my $symb;
     if ($ENV{'form.symb'}) {
       $symb=$ENV{'form.symb'};
     } else {
       $symb=&Apache::lonnet::symbread($url);
     }
   if ($symb eq '') { $request->print("Unable to handle ambiguous references:$url:."); return ''; }    if ($symb eq '') { $request->print("Unable to handle ambiguous references:$url:."); return ''; }
   my $answer=&Apache::loncommon::get_previous_attempt($symb,$uname,$udom,    my $answer=&Apache::loncommon::get_previous_attempt($symb,$uname,$udom,
       $ENV{'request.course.id'});        $ENV{'request.course.id'});
   my $result="<h2> Submission Record </h2>  $uname:$udom for $url <br />".$answer;    my $result="<h2> Submission Record </h2>  $uname:$udom for $url <br />".$answer;
     my $rendered=&Apache::loncommon::get_student_view($symb,$uname,$udom,
      $ENV{'request.course.id'});
     $result.="Student's view of the problem:<br /> $rendered <br /> Correct answer:";
   return $result;    return $result;
 }  }
   
Line 245  sub viewgrades { Line 289  sub viewgrades {
   
   #start the form    #start the form
   $result = '<form action="/adm/grades" method="post">'."\n".    $result = '<form action="/adm/grades" method="post">'."\n".
     '<input type="hidden" name="symb" value="'.$symb.'"/>'."\n".      '<input type="hidden" name="symb" value="'.$symb.'" />'."\n".
       '<input type="hidden" name="url" value="'.$url.'"/>'."\n".        '<input type="hidden" name="url" value="'.$url.'" />'."\n".
  '<input type="hidden" name="command" value="editgrades" />'."\n".   '<input type="hidden" name="command" value="editgrades" />'."\n".
   '<input type="submit" name="submit" value="Submit Changes" />'."\n".    '<input type="submit" name="submit" value="Submit Changes" />'."\n".
     '<table border=0><tr><td bgcolor="#999999">'."\n".      '<table border=0><tr><td bgcolor="#999999">'."\n".
Line 326  sub handler { Line 370  sub handler {
   }    }
   $request->send_http_header;    $request->send_http_header;
   return OK if $request->header_only;    return OK if $request->header_only;
     &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'});
   my $url=$ENV{'form.url'};    my $url=$ENV{'form.url'};
   my $symb=$ENV{'form.symb'};    my $symb=$ENV{'form.symb'};
   my $command=$ENV{'form.command'};    my $command=$ENV{'form.command'};
       if (!$url) {
       my ($temp1,$temp2);
       ($temp1,$temp2,$ENV{'form.url'})=split(/___/,$symb);
       $url = $ENV{'form.url'};
     }
   &send_header($request);    &send_header($request);
   if ($url eq '' && $symb eq '') {    if ($url eq '' && $symb eq '') {
      if ($ENV{'user.adv'}) {       if ($ENV{'user.adv'}) {

Removed from v.1.15  
changed lines
  Added in v.1.17


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