--- loncom/interface/lonevaluate.pm 2002/08/26 12:47:28 1.10 +++ loncom/interface/lonevaluate.pm 2005/02/17 08:50:20 1.16 @@ -1,7 +1,7 @@ # The LearningOnline Network # Evaluate # -# $Id: lonevaluate.pm,v 1.10 2002/08/26 12:47:28 www Exp $ +# $Id: lonevaluate.pm,v 1.16 2005/02/17 08:50:20 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -38,24 +38,27 @@ package Apache::lonevaluate; use strict; -use Apache::lonnet; +use Apache::lonnet(); use Apache::Constants qw(:common); -use Apache::loncommon; +use Apache::loncommon(); +use Apache::lonenc(); sub handler { my $r = shift; - $r->content_type('text/html'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; &Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['postdata']); - my $feedurl=$ENV{'form.postdata'}; - $feedurl=~s/^http\:\/\///; - $feedurl=~s/^$ENV{'SERVER_NAME'}//; - $feedurl=~s/^$ENV{'HTTP_HOST'}//; + my $feedurl=$ENV{'form.postdata'}; + $feedurl=~s/^http\:\/\///; + $feedurl=~s/^$ENV{'SERVER_NAME'}//; + $feedurl=~s/^$ENV{'HTTP_HOST'}//; - $feedurl=&Apache::lonnet::declutter($feedurl); - my $symb=&Apache::lonnet::symbread($feedurl); + $feedurl=&Apache::lonnet::declutter($feedurl); + + my $title=&Apache::lonnet::gettitle($feedurl); + my $showurl=&Apache::lonenc::check_encrypt($feedurl); my ($rdomain,$rauth)=($feedurl=~/^(\w+)\/(\w+)\//); @@ -89,14 +92,18 @@ sub handler { } } if ($complete) { - $r->print(<<ENDHEADER); -<html> + my $showurl=&Apache::lonenc::check_encrypt(&Apache::lonnet::clutter($feedurl)); + my $html=&Apache::lonxml::xmlbegin(); + $r->print(<<ENDHEADER); +$html <head> <title>Evaluation submitted</title> <script> - function go() { - if (window.name!='LONcatInfo') { - window.location='/res/$feedurl'; + function goback() { + if ((window.name=='loncapaclient')) { + window.location='$showurl'; + } else { + self.close(); } } </script> @@ -111,7 +118,7 @@ ENDHEADER $r->print('<br>Logging first evaluation'); } $r->print( - '<script>setTimeout("go()",2000);</script></body></html>'); + '<script>setTimeout("goback()",2000);</script></body></html>'); return OK; } else { $warning='Please fill out all fields below'; @@ -125,7 +132,8 @@ ENDHEADER foreach my $item (@items) { unless ($item eq 'comments') { - unless ($item eq 'timestamp') { + unless (($item eq 'timestamp') || + (!defined($currenteval{$prefix.$item}))) { $dialold.= 'document.evaluation.'.$item.'.selectedIndex='. $currenteval{$prefix.$item}.";\n"; @@ -134,7 +142,6 @@ ENDHEADER $oldcomments=$currenteval{$prefix.$item}; } } - # ------------------------------------------------------- Print out eval screen my $standardoptions=(<<ENDOPTIONS); <option value=0>-</option> @@ -144,19 +151,20 @@ ENDHEADER <option value=4>Agree</option> <option value=5>Strongly Agree</option> ENDOPTIONS - + + my $html=&Apache::lonxml::xmlbegin(); $r->print(<<ENDDOCUMENT); -<html> +$html <head> <title>The LearningOnline Network with CAPA</title> </head> $bodytag -<tt>$feedurl</tt><p> +<tt>$title</tt><p> <h3><font color="red">$warning</font></h3> Please rank the following criteria: <form method=post name=evaluation> <input type=hidden name=submiteval value=true> -<input type=hidden name=postdata value="$feedurl"> +<input type=hidden name=postdata value="$showurl"> The material appears to be correct <br><select name=correct> $standardoptions