';
+ }
+ }
+ }
+ unless ($discussiononly) {
+ $discussion.='';
+ }
+ }
+ if ($discussiononly) {
+ $discussion.=(<
+
+
+
+
+
+Note: in anonymous discussion, your name is visible only to
+course faculty
+
+
+Attachment (128 KB max size):
+
+
+ENDDISCUSS
+ $discussion.=&generate_preview_button();
+ }
+ return $discussion;
+}
+
sub mail_screen {
my ($r,$feedurl,$options) = @_;
my $bodytag=&Apache::loncommon::bodytag('Resource Feedback and Discussion',
'','onLoad="window.focus();"');
+ my $title=&Apache::lonnet::gettitle($feedurl);
+ if (!$title) { $title = $feedurl; }
+ my $latexHelp = Apache::loncommon::helpLatexCheatsheet();
$r->print(<
@@ -104,12 +222,14 @@ sub mail_screen {
$bodytag
-
$feedurl
-
ENDREDIR
@@ -172,7 +294,7 @@ ENDNOREDIR
$r->print (<
-
+
Sorry, no feedback possible on this resource ...
@@ -182,22 +304,23 @@ ENDNOREDIRTWO
sub screen_header {
my ($feedurl) = @_;
- my $options='';
+ my $msgoptions='';
+ my $discussoptions='';
if (($feedurl=~/^\/res\//) && ($feedurl!~/^\/res\/adm/)) {
- $options=
+ $msgoptions=
'
Feedback to resource author';
}
if (&feedback_available(1)) {
- $options.=
+ $msgoptions.=
' Question about resource content';
}
if (&feedback_available(0,1)) {
- $options.=
+ $msgoptions.=
' '.
'Question/Comment/Feedback about course content';
}
if (&feedback_available(0,0,1)) {
- $options.=
+ $msgoptions.=
' '.
'Question/Comment/Feedback about course policy';
}
@@ -206,19 +329,22 @@ sub screen_header {
if (&Apache::lonnet::allowed('pch',
$ENV{'request.course.id'}.
($ENV{'request.course.sec'}?'/'.$ENV{'request.course.sec'}:''))) {
- $options.=' '.
- 'Contribution to course discussion of resource';
- $options.=' '.
- 'Anonymous contribution to course discussion of resource'.
- ' (name only visible to course faculty)';
+ $discussoptions=' '.
+ 'Contribution to course discussion of resource';
+ $discussoptions.=' '.
+ 'Anonymous contribution to course discussion of resource'.
+ ' (name only visible to course faculty)';
}
}
- return $options;
+ if ($msgoptions) { $msgoptions='
Sending Messages
'.$msgoptions; }
+ if ($discussoptions) {
+ $discussoptions='
Discussion Contributions
'.$discussoptions; }
+ return $msgoptions.$discussoptions;
}
sub resource_output {
my ($feedurl) = @_;
- my $usersaw=&Apache::lonnet::ssi($feedurl);
+ my $usersaw=&Apache::lonnet::ssi_body($feedurl);
$usersaw=~s/\]*\>//gi;
$usersaw=~s/\<\/body\>//gi;
$usersaw=~s/\//gi;
@@ -240,9 +366,9 @@ sub clear_out_html {
BR=>1, TT=>1, STRONG=>1, BLOCKQUOTE=>1, DIV=>1, IMG=>1);
$message =~ s/\<(\/?\s*(\w+)[^\>\<]*)/
- {($html{uc($2)}&(length($1)<1000))?"\<$1":"\<$1"}/ge;
+ {($html{uc($2)}&&(length($1)<1000))?"\<$1":"\<$1"}/ge;
$message =~ s/(\\s*(\w+)[^\<\>]*)\>/
- {($html{uc($2)}&(length($1)<1000))?"$1\>":"$1\>"}/ge;
+ {($html{uc($2)}&&(length($1)<1000))?"$1\>":"$1\>"}/ge;
} else {
$message=~s/\<\/*m\s*\>//g;
$message=~s/\\<\;/g;
@@ -339,14 +465,15 @@ sub feedback_available {
}
sub send_msg {
- my ($feedurl,$email,$citations,%to)=@_;
+ my ($feedurl,$email,$citations,$attachmenturl,%to)=@_;
my $status='';
my $sendsomething=0;
foreach (keys %to) {
if ($_) {
my $declutter=&Apache::lonnet::declutter($feedurl);
unless (&Apache::lonmsg::user_normal_msg(split(/\:/,$_),
- 'Feedback ['.$declutter.']',$email,$citations,$feedurl)=~/ok/) {
+ 'Feedback ['.$declutter.']',$email,$citations,$feedurl,
+ $attachmenturl)=~/ok/) {
$status.=' Error sending message to '.$_.' ';
} else {
$sendsomething++;
@@ -382,7 +509,7 @@ sub adddiscuss {
$ENV{'environment.middlename'}.' '.
$ENV{'environment.lastname'}.' '.
$ENV{'enrironment.generation'},
- 'attachment' => $attachmenturl);
+ 'attachmenturl'=> $attachmenturl);
if ($anon) {
$contrib{'anonymous'}='true';
}
@@ -453,7 +580,7 @@ sub handler {
my $entry=$ENV{'form.hide'}?$ENV{'form.hide'}:$ENV{'form.unhide'};
my ($symb,$idx)=split(/\:\:\:/,$entry);
- my ($map,$ind,$url)=split(/\_\_\_/,$symb);
+ my ($map,$ind,$url)=&Apache::lonnet::decode_symb($symb);
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'},
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
@@ -483,7 +610,7 @@ sub handler {
my $entry=$ENV{'form.deldisc'};
my ($symb,$idx)=split(/\:\:\:/,$entry);
- my ($map,$ind,$url)=split(/\_\_\_/,$symb);
+ my ($map,$ind,$url)=&Apache::lonnet::decode_symb($symb);
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'},
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'},
@@ -516,7 +643,7 @@ sub handler {
unless ($symb) {
$symb=$ENV{'form.symb'};
if ($symb) {
- my ($map,$id,$url)=split(/\_\_\_/,$symb);
+ my ($map,$id,$url)=&Apache::lonnet::decode_symb($symb);
$feedurl=&Apache::lonnet::clutter($url);
}
}
@@ -557,15 +684,17 @@ sub handler {
# Get output from resource
my $usersaw=&resource_output($feedurl);
-# Get resource answer
+# Get resource answer (need to allow student to view grades for this to work)
+ &Apache::lonnet::appenv(('allowed.vgr'=>'F'));
my $useranswer=&Apache::loncommon::get_student_answers(
$symb,$ENV{'user.name'},$ENV{'user.domain'},
$ENV{'request.course.id'});
+ &Apache::lonnet::delenv('allowed.vgr');
# Get attachments, if any, and not too large
my $attachmenturl='';
if ($ENV{'form.attachment.filename'}) {
unless (length($ENV{'form.attachment'})>131072) {
- $attachmenturl=&Apache::lonnet::userfileupload('attachment',1);
+ $attachmenturl=&Apache::lonnet::userfileupload('attachment');
}
}
# Filter HTML out of message (could be nasty)
@@ -579,7 +708,8 @@ sub handler {
my ($typestyle,%to) = &decide_receiver($feedurl);
# Actually send mail
- my ($status,$numsent)=&send_msg($feedurl,$email,$citations,%to);
+ my ($status,$numsent)=&send_msg($feedurl,$email,$citations,
+ $attachmenturl,%to);
# Discussion? Store that.
@@ -605,7 +735,10 @@ sub handler {
}
} else {
# Ambiguous Problem Resource
- $r->internal_redirect('/adm/ambiguous');
+ if ( Apache::exists_config_define("MODPERL2") ) {
+ &Apache::lonnet::cleanenv();
+ }
+ $r->internal_redirect('/adm/ambiguous');
}
}
return OK;