--- 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