version 1.153, 2005/02/17 08:29:42
|
version 1.173, 2005/11/10 11:31:04
|
Line 35 use Apache::lonmsg();
|
Line 35 use Apache::lonmsg();
|
use Apache::loncommon(); |
use Apache::loncommon(); |
use Apache::lontexconvert(); |
use Apache::lontexconvert(); |
use Apache::lonlocal; # must not have () |
use Apache::lonlocal; # must not have () |
|
use Apache::lonnet; |
use Apache::lonhtmlcommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonnavmaps; |
use Apache::lonnavmaps; |
use Apache::lonenc(); |
use Apache::lonenc(); |
Line 44 use Cwd;
|
Line 45 use Cwd;
|
|
|
sub discussion_open { |
sub discussion_open { |
my ($status,$symb)=@_; |
my ($status,$symb)=@_; |
|
if ($env{'request.role.adv'}) { return 1; } |
if (defined($status) && |
if (defined($status) && |
!($status eq 'CAN_ANSWER' || $status eq 'CANNOT_ANSWER' |
!($status eq 'CAN_ANSWER' || $status eq 'CANNOT_ANSWER' |
|| $status eq 'OPEN')) { |
|| $status eq 'OPEN')) { |
Line 61 sub discussion_visible {
|
Line 63 sub discussion_visible {
|
if (not &discussion_open($status)) { |
if (not &discussion_open($status)) { |
my $hidden=&Apache::lonnet::EXT('resource.0.discusshide'); |
my $hidden=&Apache::lonnet::EXT('resource.0.discusshide'); |
if (lc($hidden) eq 'yes' or $hidden eq '' or !defined($hidden)) { |
if (lc($hidden) eq 'yes' or $hidden eq '' or !defined($hidden)) { |
if (!$ENV{'request.role.adv'}) { return 0; } |
if (!$env{'request.role.adv'}) { return 0; } |
} |
} |
} |
} |
return 1; |
return 1; |
Line 69 sub discussion_visible {
|
Line 71 sub discussion_visible {
|
|
|
sub list_discussion { |
sub list_discussion { |
my ($mode,$status,$ressymb,$imsextras)=@_; |
my ($mode,$status,$ressymb,$imsextras)=@_; |
my $outputtarget=$ENV{'form.grade_target'}; |
my $outputtarget=$env{'form.grade_target'}; |
if (defined($ENV{'form.export'})) { |
if (defined($env{'form.export'})) { |
if($ENV{'form.export'}) { |
if($env{'form.export'}) { |
$outputtarget = 'export'; |
$outputtarget = 'export'; |
} |
} |
} |
} |
Line 84 sub list_discussion {
|
Line 86 sub list_discussion {
|
my @bgcols = ("#cccccc","#eeeeee"); |
my @bgcols = ("#cccccc","#eeeeee"); |
my $discussiononly=0; |
my $discussiononly=0; |
if ($mode eq 'board') { $discussiononly=1; } |
if ($mode eq 'board') { $discussiononly=1; } |
unless ($ENV{'request.course.id'}) { return ''; } |
unless ($env{'request.course.id'}) { return ''; } |
my $crs='/'.$ENV{'request.course.id'}; |
my $crs='/'.$env{'request.course.id'}; |
my $cid=$ENV{'request.course.id'}; |
my $cid=$env{'request.course.id'}; |
if ($ENV{'request.course.sec'}) { |
if ($env{'request.course.sec'}) { |
$crs.='_'.$ENV{'request.course.sec'}; |
$crs.='_'.$env{'request.course.sec'}; |
} |
} |
$crs=~s/\_/\//g; |
$crs=~s/\_/\//g; |
unless ($ressymb) { $ressymb=&Apache::lonnet::symbread(); } |
unless ($ressymb) { $ressymb=&Apache::lonnet::symbread(); } |
Line 96 sub list_discussion {
|
Line 98 sub list_discussion {
|
$ressymb=&wrap_symb($ressymb); |
$ressymb=&wrap_symb($ressymb); |
my $encsymb=&Apache::lonenc::check_encrypt($ressymb); |
my $encsymb=&Apache::lonenc::check_encrypt($ressymb); |
my $viewgrades=(&Apache::lonnet::allowed('vgr',$crs) |
my $viewgrades=(&Apache::lonnet::allowed('vgr',$crs) |
&& ($ressymb=~/\.(problem|exam|quiz|assess|survey|form)$/)); |
&& ($ressymb=~/\.(problem|exam|quiz|assess|survey|form|task)$/)); |
|
|
my %usernamesort = (); |
my %usernamesort = (); |
my %namesort =(); |
my %namesort =(); |
Line 112 sub list_discussion {
|
Line 114 sub list_discussion {
|
my $toggkey = $ressymb.'_readtoggle'; |
my $toggkey = $ressymb.'_readtoggle'; |
my $readkey = $ressymb.'_read'; |
my $readkey = $ressymb.'_read'; |
$ressymb=$encsymb; |
$ressymb=$encsymb; |
my %dischash = &Apache::lonnet::get('nohist_'.$ENV{'request.course.id'}.'_discuss',[$lastkey,$showkey,$markkey,$visitkey,$ondispkey,$userpickkey,$toggkey,$readkey],$ENV{'user.domain'},$ENV{'user.name'}); |
my %dischash = &Apache::lonnet::get('nohist_'.$cid.'_discuss',[$lastkey,$showkey,$markkey,$visitkey,$ondispkey,$userpickkey,$toggkey,$readkey],$env{'user.domain'},$env{'user.name'}); |
my %discinfo = (); |
my %discinfo = (); |
my $showonlyunread = 0; |
my $showonlyunread = 0; |
my $showunmark = 0; |
my $showunmark = 0; |
Line 125 sub list_discussion {
|
Line 127 sub list_discussion {
|
|
|
# Retain identification of "NEW" posts identified in last display, if continuing 'previous' browsing of posts. |
# Retain identification of "NEW" posts identified in last display, if continuing 'previous' browsing of posts. |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['previous','sortposts','rolefilter','statusfilter','sectionpick','totposters']); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['previous','sortposts','rolefilter','statusfilter','sectionpick','totposters']); |
my $sortposts = $ENV{'form.sortposts'}; |
my $sortposts = $env{'form.sortposts'}; |
my $statusfilter = $ENV{'form.statusfilter'}; |
my $statusfilter = $env{'form.statusfilter'}; |
my @sectionpick = (); |
my @sectionpick = (); |
if ($ENV{'form.sectionpick'} =~ /,/) { |
if ($env{'form.sectionpick'} =~ /,/) { |
@sectionpick = split/,/,$ENV{'form.sectionpick'}; |
@sectionpick = split/,/,$env{'form.sectionpick'}; |
} else { |
} else { |
$sectionpick[0] = $ENV{'form.sectionpick'}; |
$sectionpick[0] = $env{'form.sectionpick'}; |
} |
} |
my @rolefilter = (); |
my @rolefilter = (); |
if ($ENV{'form.rolefilter'} =~ /,/) { |
if ($env{'form.rolefilter'} =~ /,/) { |
@rolefilter = split/,/,$ENV{'form.rolefilter'}; |
@rolefilter = split/,/,$env{'form.rolefilter'}; |
} else { |
} else { |
$rolefilter[0] = $ENV{'form.rolefilter'}; |
$rolefilter[0] = $env{'form.rolefilter'}; |
} |
} |
my $totposters = $ENV{'form.totposters'}; |
my $totposters = $env{'form.totposters'}; |
$previous = $ENV{'form.previous'}; |
$previous = $env{'form.previous'}; |
if ($previous > 0) { |
if ($previous > 0) { |
$prevread = $previous; |
$prevread = $previous; |
} elsif (defined($dischash{$lastkey})) { |
} elsif (defined($dischash{$lastkey})) { |
Line 152 sub list_discussion {
|
Line 154 sub list_discussion {
|
# Get information about students and non-students in course for filtering display of posts |
# Get information about students and non-students in course for filtering display of posts |
my %roleshash = (); |
my %roleshash = (); |
my %roleinfo = (); |
my %roleinfo = (); |
if ($ENV{'form.rolefilter'}) { |
if ($env{'form.rolefilter'}) { |
%roleshash = &Apache::lonnet::dump('nohist_userroles',$ENV{'course.'.$ENV{'request.course.id'}.'.domain'},$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
%roleshash = &Apache::lonnet::dump('nohist_userroles', |
|
$env{'course.'.$cid.'.domain'}, |
|
$env{'course.'.$cid.'.num'}); |
foreach (keys %roleshash) { |
foreach (keys %roleshash) { |
my ($role,$uname,$udom,$sec) = split/:/,$_; |
my ($role,$uname,$udom,$sec) = split/:/,$_; |
if ($role =~ /^cr/) { |
if ($role =~ /^cr/) { |
Line 170 sub list_discussion {
|
Line 174 sub list_discussion {
|
} |
} |
} |
} |
my ($classlist) = &Apache::loncoursedata::get_classlist( |
my ($classlist) = &Apache::loncoursedata::get_classlist( |
$ENV{'request.course.id'}, |
$env{'course.'.$cid.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$cid.'.num'}); |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
|
my $sec_index = &Apache::loncoursedata::CL_SECTION(); |
my $sec_index = &Apache::loncoursedata::CL_SECTION(); |
my $status_index = &Apache::loncoursedata::CL_STATUS(); |
my $status_index = &Apache::loncoursedata::CL_STATUS(); |
while (my ($student,$data) = each %$classlist) { |
while (my ($student,$data) = each %$classlist) { |
Line 183 sub list_discussion {
|
Line 186 sub list_discussion {
|
} |
} |
|
|
# Get discussion display default settings for user |
# Get discussion display default settings for user |
if ($ENV{'environment.discdisplay'} eq 'unread') { |
if ($env{'environment.discdisplay'} eq 'unread') { |
$showonlyunread = 1; |
$showonlyunread = 1; |
} |
} |
if ($ENV{'environment.discmarkread'} eq 'ondisp') { |
if ($env{'environment.discmarkread'} eq 'ondisp') { |
$markondisp = 1; |
$markondisp = 1; |
} |
} |
|
|
Line 234 sub list_discussion {
|
Line 237 sub list_discussion {
|
my %notshown = (); |
my %notshown = (); |
my %newitem = (); |
my %newitem = (); |
my $maxdepth=0; |
my $maxdepth=0; |
|
my %anonhash=(); |
|
my $anoncnt=0; |
my $target=''; |
my $target=''; |
unless ($ENV{'browser.interface'} eq 'textual' || |
unless ($env{'browser.interface'} eq 'textual' || |
$ENV{'environment.remote'} eq 'off' ) { |
$env{'environment.remote'} eq 'off' ) { |
$target='target="LONcom"'; |
$target='target="LONcom"'; |
} |
} |
|
|
my $now = time; |
my $now = time; |
$discinfo{$visitkey} = $visit; |
$discinfo{$visitkey} = $visit; |
|
|
&Apache::lonnet::put('nohist_'.$ENV{'request.course.id'}.'_discuss',\%discinfo,$ENV{'user.domain'},$ENV{'user.name'}); |
&Apache::lonnet::put('nohist_'.$cid.'_discuss',\%discinfo,$env{'user.domain'},$env{'user.name'}); |
&build_posting_display(\%usernamesort,\%subjectsort,\%namesort,\%notshown,\%newitem,\%dischash,\%shown,\%alldiscussion,\%imsitems,\%imsfiles,\%roleinfo,\@discussionitems,\@replies,\@depth,\@posters,\$maxdepth,\$visible,\$newpostsflag,\$current,$status,$viewgrades,$seeid,$prevread,$sortposts,$encsymb,$target,$readkey,$showunmark,$showonlyunread,$totposters,\@rolefilter,\@sectionpick,$statusfilter,$toggkey,$outputtarget); |
&build_posting_display(\%usernamesort,\%subjectsort,\%namesort,\%notshown,\%newitem,\%dischash,\%shown,\%alldiscussion,\%imsitems,\%imsfiles,\%roleinfo,\@discussionitems,\@replies,\@depth,\@posters,\$maxdepth,\$visible,\$newpostsflag,\$current,$status,$viewgrades,$seeid,$prevread,$sortposts,$encsymb,$target,$readkey,$showunmark,$showonlyunread,$totposters,\@rolefilter,\@sectionpick,$statusfilter,$toggkey,$outputtarget,\%anonhash,$anoncnt); |
|
|
my $discussion=''; |
my $discussion=''; |
my $manifestfile; |
my $manifestfile; |
Line 256 sub list_discussion {
|
Line 260 sub list_discussion {
|
|
|
my $function = &Apache::loncommon::get_users_function(); |
my $function = &Apache::loncommon::get_users_function(); |
my $color = &Apache::loncommon::designparm($function.'.tabbg', |
my $color = &Apache::loncommon::designparm($function.'.tabbg', |
$ENV{'user.domain'}); |
$env{'user.domain'}); |
my %lt = &Apache::lonlocal::texthash( |
my %lt = &Apache::lonlocal::texthash( |
'cuse' => 'Current discussion settings', |
'cuse' => 'Current discussion settings', |
'allposts' => 'All posts', |
'allposts' => 'All posts', |
Line 322 sub list_discussion {
|
Line 326 sub list_discussion {
|
if ($visible) { |
if ($visible) { |
# Print the discusssion |
# Print the discusssion |
if ($outputtarget eq 'tex') { |
if ($outputtarget eq 'tex') { |
$discussion.='<tex>\vskip 0 mm\noindent\makebox[2 cm][b]{\hrulefill}'. |
$discussion.='<tex>{\tiny \vskip 0 mm\noindent\makebox[2 cm][b]{\hrulefill}'. |
'\textbf{DISCUSSIONS}\makebox[2 cm][b]{\hrulefill}'. |
'\textbf{DISCUSSIONS}\makebox[2 cm][b]{\hrulefill}'. |
'\vskip 0 mm\noindent\textbf{'.$lt{'cuse'}.'}:\vskip 0 mm'. |
'\vskip 0 mm\noindent\textbf{'.$lt{'cuse'}.'}:\vskip 0 mm'. |
'\noindent\textbf{'.$lt{'disa'}.'}: \textit{'.$currdisp.'}\vskip 0 mm'. |
'\noindent\textbf{'.$lt{'disa'}.'}: \textit{'.$currdisp.'}\vskip 0 mm'. |
'\noindent\textbf{'.$lt{'npce'}.'}: \textit{'.$currmark.'}</tex>'; |
'\noindent\textbf{'.$lt{'npce'}.'}: \textit{'.$currmark.'}}</tex>'; |
} elsif ($outputtarget eq 'export') { |
} elsif ($outputtarget eq 'export') { |
# Create temporary directory if this is an export |
# Create temporary directory if this is an export |
my $now = time; |
my $now = time; |
Line 348 sub list_discussion {
|
Line 352 sub list_discussion {
|
if (!-e $tempexport) { |
if (!-e $tempexport) { |
mkdir($tempexport,0700); |
mkdir($tempexport,0700); |
} |
} |
$tempexport .= '/'.$ENV{'user.domain'}.'_'.$ENV{'user.name'}; |
$tempexport .= '/'.$env{'user.domain'}.'_'.$env{'user.name'}; |
} |
} |
if (!-e $tempexport) { |
if (!-e $tempexport) { |
mkdir($tempexport,0700); |
mkdir($tempexport,0700); |
Line 389 imscp_v1p1.xsd http://www.imsglobal.org/
|
Line 393 imscp_v1p1.xsd http://www.imsglobal.org/
|
$discussion.='<form name="readchoices" method="post" action="/adm/feedback?chgreads='.$ressymb.'" ><table bgcolor="#AAAAAA" cellpadding="2" cellspacing="2" border="0">'; |
$discussion.='<form name="readchoices" method="post" action="/adm/feedback?chgreads='.$ressymb.'" ><table bgcolor="#AAAAAA" cellpadding="2" cellspacing="2" border="0">'; |
$discussion .='<tr><td bgcolor="#DDDDBB" colspan="'.$colspan.'">'. |
$discussion .='<tr><td bgcolor="#DDDDBB" colspan="'.$colspan.'">'. |
'<table border="0" width="100%" bgcolor="#DDDDBB"><tr>'; |
'<table border="0" width="100%" bgcolor="#DDDDBB"><tr>'; |
|
my $escsymb=&Apache::lonnet::escape($ressymb); |
if ($visible>2) { |
if ($visible>2) { |
$discussion.='<td align="left">'. |
$discussion.='<td align="left">'. |
'<a href="/adm/feedback?cmd=threadedon&symb='.$ressymb; |
'<a href="/adm/feedback?cmd=threadedon&symb='.$escsymb; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$discussion .= '&previous='.$prevread; |
$discussion .= '&previous='.$prevread; |
} |
} |
$discussion .='">'.&mt('Threaded View').'</a> '. |
$discussion .='">'.&mt('Threaded View').'</a> '. |
'<a href="/adm/feedback?cmd=threadedoff&symb='.$ressymb; |
'<a href="/adm/feedback?cmd=threadedoff&symb='.$escsymb; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$discussion .= '&previous='.$prevread; |
$discussion .= '&previous='.$prevread; |
} |
} |
$discussion .='">'.&mt('Chronological View').'</a> |
$discussion .='">'.&mt('Chronological View').'</a> |
<a href= "/adm/feedback?cmd=sortfilter&symb='.$ressymb; |
<a href= "/adm/feedback?cmd=sortfilter&symb='.$escsymb; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$discussion .= '&previous='.$prevread; |
$discussion .= '&previous='.$prevread; |
} |
} |
Line 409 imscp_v1p1.xsd http://www.imsglobal.org/
|
Line 414 imscp_v1p1.xsd http://www.imsglobal.org/
|
} else { |
} else { |
$discussion .= '<td align="left">'; |
$discussion .= '<td align="left">'; |
} |
} |
$discussion .='<a href= "/adm/feedback?export='.$ressymb; |
$discussion .='<a href= "/adm/feedback?export='.$escsymb; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$discussion .= '&previous='.$prevread; |
$discussion .= '&previous='.$prevread; |
} |
} |
$discussion .= '">'.&mt('Export').'?</a> </td>'; |
$discussion .= '">'.&mt('Export').'?</a> </td>'; |
if ($newpostsflag) { |
if ($newpostsflag) { |
if (!$markondisp) { |
if (!$markondisp) { |
$discussion .='<td align="right"><a href="/adm/feedback?markread=1&symb='.$ressymb.'">'.&mt('Mark NEW posts no longer new').'</a> '; |
$discussion .='<td align="right"><a href="/adm/preferences?action=changediscussions">'. |
|
&mt('Preferences on what is marked as NEW'). |
|
'</a><br /><a href="/adm/feedback?markread=1&symb='.$escsymb.'">'.&mt('Mark NEW posts no longer new').'</a>'; |
} else { |
} else { |
$discussion .= '<td> </td>'; |
$discussion .= '<td> </td>'; |
} |
} |
Line 429 imscp_v1p1.xsd http://www.imsglobal.org/
|
Line 436 imscp_v1p1.xsd http://www.imsglobal.org/
|
if ($numhidden > 0) { |
if ($numhidden > 0) { |
my $colspan = $maxdepth+1; |
my $colspan = $maxdepth+1; |
$discussion.="\n".'<tr><td bgcolor="#CCCCCC" colspan="'.$colspan.'">'. |
$discussion.="\n".'<tr><td bgcolor="#CCCCCC" colspan="'.$colspan.'">'. |
'<a href="/adm/feedback?allposts=1&symb='.$ressymb; |
'<a href="/adm/feedback?allposts=1&symb='.$escsymb; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$discussion .= '&previous='.$prevread; |
$discussion .= '&previous='.$prevread; |
} |
} |
Line 472 imscp_v1p1.xsd http://www.imsglobal.org/
|
Line 479 imscp_v1p1.xsd http://www.imsglobal.org/
|
my $currdepth = 0; |
my $currdepth = 0; |
my $firstidx = $alldiscussion{$showposts[0]}; |
my $firstidx = $alldiscussion{$showposts[0]}; |
foreach (@showposts) { |
foreach (@showposts) { |
unless (($sortposts eq 'thread') || (($sortposts eq '') && ($ENV{'environment.threadeddiscussion'})) || ($outputtarget eq 'export')) { |
unless (($sortposts eq 'thread') || (($sortposts eq '') && ($env{'environment.threadeddiscussion'})) || ($outputtarget eq 'export')) { |
$alldiscussion{$_} = $_; |
$alldiscussion{$_} = $_; |
} |
} |
unless ( ($notshown{$alldiscussion{$_}} eq '1') || ($shown{$alldiscussion{$_}} == 0) ) { |
unless ( ($notshown{$alldiscussion{$_}} eq '1') || ($shown{$alldiscussion{$_}} == 0) ) { |
Line 584 END
|
Line 591 END
|
&sort_filter_names(\%sort_types,\%role_types,\%status_types); |
&sort_filter_names(\%sort_types,\%role_types,\%status_types); |
|
|
$discussion .= '<td><font size="-1"><b>'.&mt('Sorted by').'</b>: '.$sort_types{$sortposts}.'<br />'; |
$discussion .= '<td><font size="-1"><b>'.&mt('Sorted by').'</b>: '.$sort_types{$sortposts}.'<br />'; |
if (defined($ENV{'form.totposters'})) { |
if (defined($env{'form.totposters'})) { |
$discussion .= &mt('Posts by').':'; |
$discussion .= &mt('Posts by').':'; |
if ($totposters > 0) { |
if ($totposters > 0) { |
foreach my $poster (@posters) { |
foreach my $poster (@posters) { |
Line 598 END
|
Line 605 END
|
} else { |
} else { |
my $filterchoice =''; |
my $filterchoice =''; |
if (@sectionpick > 0) { |
if (@sectionpick > 0) { |
$filterchoice = '<i>'.&mt('sections').'</i>- '.$ENV{'form.sectionpick'}; |
$filterchoice = '<i>'.&mt('sections').'</i>- '.$env{'form.sectionpick'}; |
$filterchoice .= ' '; |
$filterchoice .= ' '; |
} |
} |
if (@rolefilter > 0) { |
if (@rolefilter > 0) { |
Line 657 END
|
Line 664 END
|
#Create zip file in prtspool |
#Create zip file in prtspool |
|
|
my $imszipfile = '/prtspool/'. |
my $imszipfile = '/prtspool/'. |
$ENV{'user.name'}.'_'.$ENV{'user.domain'}.'_'. |
$env{'user.name'}.'_'.$env{'user.domain'}.'_'. |
time.'_'.rand(1000000000).'.zip'; |
time.'_'.rand(1000000000).'.zip'; |
# zip can cause an sh launch which can pass along all of %ENV |
|
# which can be too large for /bin/sh to handle |
|
my %oldENV=%ENV; |
|
undef(%ENV); |
|
my $cwd = &getcwd(); |
my $cwd = &getcwd(); |
my $imszip = '/home/httpd/'.$imszipfile; |
my $imszip = '/home/httpd/'.$imszipfile; |
chdir $tempexport; |
chdir $tempexport; |
open(OUTPUT, "zip -r $imszip * 2> /dev/null |"); |
open(OUTPUT, "zip -r $imszip * 2> /dev/null |"); |
close(OUTPUT); |
close(OUTPUT); |
chdir $cwd; |
chdir $cwd; |
%ENV=%oldENV; |
|
undef(%oldENV); |
|
$discussion .= 'Download the zip file from <a href="'.$imszipfile.'">Discussion Posting Archive</a><br />'; |
$discussion .= 'Download the zip file from <a href="'.$imszipfile.'">Discussion Posting Archive</a><br />'; |
if ($copyresult) { |
if ($copyresult) { |
$discussion .= 'The following errors occurred during export - <br />'.$copyresult; |
$discussion .= 'The following errors occurred during export - <br />'.$copyresult; |
Line 690 END
|
Line 691 END
|
my @currdelold = (); |
my @currdelold = (); |
my $comment = ''; |
my $comment = ''; |
my $subject = ''; |
my $subject = ''; |
if ($ENV{'form.origpage'}) { |
if ($env{'form.origpage'}) { |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['addnewattach','deloldattach','delnewattach','timestamp','idx','subject','comment']); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['addnewattach','deloldattach','delnewattach','timestamp','idx','subject','comment']); |
$subject = &Apache::lonnet::unescape($ENV{'form.subject'}); |
$subject = &Apache::lonnet::unescape($env{'form.subject'}); |
$comment = &Apache::lonnet::unescape($ENV{'form.comment'}); |
$comment = &Apache::lonnet::unescape($env{'form.comment'}); |
my @keepold = (); |
my @keepold = (); |
&process_attachments(\@currnewattach,\@currdelold,\@keepold); |
&process_attachments(\@currnewattach,\@currdelold,\@keepold); |
if (@currnewattach > 0) { |
if (@currnewattach > 0) { |
Line 714 to course faculty</font><br />
|
Line 715 to course faculty</font><br />
|
<b>Title:</b> <input type="text" name="subject" value="$subject" size="30" /><br /><br /> |
<b>Title:</b> <input type="text" name="subject" value="$subject" size="30" /><br /><br /> |
<textarea name="comment" cols="80" rows="14" wrap="hard">$comment</textarea> |
<textarea name="comment" cols="80" rows="14" wrap="hard">$comment</textarea> |
ENDDISCUSS |
ENDDISCUSS |
if ($ENV{'form.origpage'}) { |
if ($env{'form.origpage'}) { |
$discussion.='<input type="hidden" name="origpage" value="'.$ENV{'form.origpage'}.'" />'."\n"; |
$discussion.='<input type="hidden" name="origpage" value="'.$env{'form.origpage'}.'" />'."\n"; |
foreach (@currnewattach) { |
foreach (@currnewattach) { |
$discussion.='<input type="hidden" name="currnewattach" value="'.$_.'" />'."\n"; |
$discussion.='<input type="hidden" name="currnewattach" value="'.$_.'" />'."\n"; |
} |
} |
Line 744 ENDDISCUSS
|
Line 745 ENDDISCUSS
|
} else { |
} else { |
if (&discussion_open($status) && |
if (&discussion_open($status) && |
&Apache::lonnet::allowed('pch', |
&Apache::lonnet::allowed('pch', |
$ENV{'request.course.id'}. |
$env{'request.course.id'}. |
($ENV{'request.course.sec'}?'/'.$ENV{'request.course.sec'}:''))) { |
($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))) { |
if ($outputtarget ne 'tex') { |
if ($outputtarget ne 'tex') { |
$discussion.='<table bgcolor="#BBBBBB"><tr><td><a href="/adm/feedback?replydisc='. |
$discussion.='<table bgcolor="#BBBBBB"><tr><td><a href="/adm/feedback?replydisc='. |
$ressymb.':::" '.$target.'>'. |
&Apache::lonnet::escape($ressymb).':::" '.$target.'>'. |
'<img src="'.&Apache::loncommon::lonhttpdurl('/adm/lonMisc/chat.gif').'" border="0" />'. |
'<img src="'.&Apache::loncommon::lonhttpdurl('/adm/lonMisc/chat.gif').'" border="0" />'. |
&mt('Post Discussion').'</a></td></tr></table>'; |
&mt('Post Discussion').'</a></td></tr></table>'; |
} |
} |
Line 758 ENDDISCUSS
|
Line 759 ENDDISCUSS
|
} |
} |
|
|
sub build_posting_display { |
sub build_posting_display { |
my ($usernamesort,$subjectsort,$namesort,$notshown,$newitem,$dischash,$shown,$alldiscussion,$imsitems,$imsfiles,$roleinfo,$discussionitems,$replies,$depth,$posters,$maxdepth,$visible,$newpostsflag,$current,$status,$viewgrades,$seeid,$prevread,$sortposts,$ressymb,$target,$readkey,$showunmark,$showonlyunread,$totposters,$rolefilter,$sectionpick,$statusfilter,$toggkey,$outputtarget) = @_; |
my ($usernamesort,$subjectsort,$namesort,$notshown,$newitem,$dischash,$shown,$alldiscussion,$imsitems,$imsfiles,$roleinfo,$discussionitems,$replies,$depth,$posters,$maxdepth,$visible,$newpostsflag,$current,$status,$viewgrades,$seeid,$prevread,$sortposts,$ressymb,$target,$readkey,$showunmark,$showonlyunread,$totposters,$rolefilter,$sectionpick,$statusfilter,$toggkey,$outputtarget,$anonhash,$anoncnt) = @_; |
my @original=(); |
my @original=(); |
my @index=(); |
my @index=(); |
my $symb=&Apache::lonenc::check_decrypt($ressymb); |
my $symb=&Apache::lonenc::check_decrypt($ressymb); |
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my $escsymb=&Apache::lonnet::escape($ressymb); |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
|
$env{'course.'.$env{'request.course.id'}.'.num'}); |
|
|
if ($contrib{'version'}) { |
if ($contrib{'version'}) { |
my $oldest = $contrib{'1:timestamp'}; |
my $oldest = $contrib{'1:timestamp'}; |
Line 788 sub build_posting_display {
|
Line 790 sub build_posting_display {
|
my $origindex='0.'; |
my $origindex='0.'; |
my $numoldver=0; |
my $numoldver=0; |
if ($contrib{$idx.':replyto'}) { |
if ($contrib{$idx.':replyto'}) { |
if ( (($ENV{'environment.threadeddiscussion'}) && ($sortposts eq '')) || ($sortposts eq 'thread') || ($outputtarget eq 'export')) { |
if ( (($env{'environment.threadeddiscussion'}) && ($sortposts eq '')) || ($sortposts eq 'thread') || ($outputtarget eq 'export')) { |
# this is a follow-up message |
# this is a follow-up message |
$original[$idx]=$original[$contrib{$idx.':replyto'}]; |
$original[$idx]=$original[$contrib{$idx.':replyto'}]; |
$$depth[$idx]=$$depth[$contrib{$idx.':replyto'}]+1; |
$$depth[$idx]=$$depth[$contrib{$idx.':replyto'}]+1; |
Line 825 sub build_posting_display {
|
Line 827 sub build_posting_display {
|
my %allattachments = (); |
my %allattachments = (); |
my ($screenname,$plainname); |
my ($screenname,$plainname); |
my $sender = &mt('Anonymous'); |
my $sender = &mt('Anonymous'); |
|
# Anonymous users getting number within a discussion |
|
# Since idx is in static order, this should give the same sequence every time. |
|
my $key=$contrib{$idx.':sendername'}.'@'.$contrib{$idx.':senderdomain'}; |
|
unless ($$anonhash{$key}) { |
|
$anoncnt++; |
|
$$anonhash{$key}=&mt('Anonymous').' '.$anoncnt; |
|
} |
my ($message,$subject,$vgrlink,$ctlink); |
my ($message,$subject,$vgrlink,$ctlink); |
&get_post_contents(\%contrib,$idx,$seeid,$outputtarget,\%messages,\%subjects,\%allattachments,\%attachtxt,$imsfiles,\$screenname,\$plainname,$numoldver); |
&get_post_contents(\%contrib,$idx,$seeid,$outputtarget,\%messages,\%subjects,\%allattachments,\%attachtxt,$imsfiles,\$screenname,\$plainname,$numoldver); |
|
|
Line 863 sub build_posting_display {
|
Line 872 sub build_posting_display {
|
$contrib{$idx.':sendername'}.' at '. |
$contrib{$idx.':sendername'}.' at '. |
$contrib{$idx.':senderdomain'}.')'; |
$contrib{$idx.':senderdomain'}.')'; |
if ($contrib{$idx.':anonymous'}) { |
if ($contrib{$idx.':anonymous'}) { |
$sender.=' ['.&mt('anonymous').'] '. |
$sender.=' <font color="red"><b>['.$$anonhash{$key}.']</b></font> '. |
$screenname; |
$screenname; |
} |
} |
|
|
Line 896 sub build_posting_display {
|
Line 905 sub build_posting_display {
|
} else { |
} else { |
@{$$namesort{$lastname}{$firstname}} = ("$idx"); |
@{$$namesort{$lastname}{$firstname}} = ("$idx"); |
} |
} |
if ($ENV{'course.'.$ENV{'request.course.id'}.'.allow_discussion_post_editing'} =~ m/yes/i) { |
if ($env{'course.'.$env{'request.course.id'}.'.allow_discussion_post_editing'} =~ m/yes/i) { |
if (($ENV{'user.domain'} eq $contrib{$idx.':senderdomain'}) && ($ENV{'user.name'} eq $contrib{$idx.':sendername'})) { |
if (($env{'user.domain'} eq $contrib{$idx.':senderdomain'}) && ($env{'user.name'} eq $contrib{$idx.':sendername'})) { |
$sender.=' <a href="/adm/feedback?editdisc='. |
$sender.=' <a href="/adm/feedback?editdisc='. |
$ressymb.':::'.$idx; |
$escsymb.':::'.$idx; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$sender .= '&previous='.$prevread; |
$sender .= '&previous='.$prevread; |
} |
} |
$sender .= '" '.$target.'>'.&mt('Edit').'</a>'; |
$sender .= '" '.$target.'>'.&mt('Edit').'</a>'; |
unless ($seeid) { |
unless ($seeid) { |
$sender.=" <a href=\"javascript:studentdelete('$ressymb','$idx','$newpostsflag','$prevread')"; |
$sender.=" <a href=\"javascript:studentdelete('$escsymb','$idx','$newpostsflag','$prevread')"; |
$sender .= '">'.&mt('Delete').'</a>'; |
$sender .= '">'.&mt('Delete').'</a>'; |
} |
} |
} |
} |
Line 914 sub build_posting_display {
|
Line 923 sub build_posting_display {
|
if ($hidden) { |
if ($hidden) { |
unless ($studenthidden) { |
unless ($studenthidden) { |
$sender.=' <a href="/adm/feedback?unhide='. |
$sender.=' <a href="/adm/feedback?unhide='. |
$ressymb.':::'.$idx; |
$escsymb.':::'.$idx; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$sender .= '&previous='.$prevread; |
$sender .= '&previous='.$prevread; |
} |
} |
Line 922 sub build_posting_display {
|
Line 931 sub build_posting_display {
|
} |
} |
} else { |
} else { |
$sender.=' <a href="/adm/feedback?hide='. |
$sender.=' <a href="/adm/feedback?hide='. |
$ressymb.':::'.$idx; |
$escsymb.':::'.$idx; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$sender .= '&previous='.$prevread; |
$sender .= '&previous='.$prevread; |
} |
} |
$sender .= '">'.&mt('Hide').'</a>'; |
$sender .= '">'.&mt('Hide').'</a>'; |
} |
} |
$sender.=' <a href="/adm/feedback?deldisc='. |
$sender.=' <a href="/adm/feedback?deldisc='. |
$ressymb.':::'.$idx; |
$escsymb.':::'.$idx; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$sender .= '&previous='.$prevread; |
$sender .= '&previous='.$prevread; |
} |
} |
Line 938 sub build_posting_display {
|
Line 947 sub build_posting_display {
|
} else { |
} else { |
if ($screenname) { |
if ($screenname) { |
$sender='<i>'.$screenname.'</i>'; |
$sender='<i>'.$screenname.'</i>'; |
|
} else { |
|
$sender='<i>'.$$anonhash{$key}.'</i>'; |
} |
} |
# Set up for sorting by domain, then username for anonymous |
# Set up for sorting by domain, then username for anonymous |
unless (defined($$usernamesort{'__anon'})) { |
unless (defined($$usernamesort{'__anon'})) { |
Line 960 sub build_posting_display {
|
Line 971 sub build_posting_display {
|
} |
} |
if (&discussion_open($status) && |
if (&discussion_open($status) && |
&Apache::lonnet::allowed('pch', |
&Apache::lonnet::allowed('pch', |
$ENV{'request.course.id'}. |
$env{'request.course.id'}. |
($ENV{'request.course.sec'}?'/'.$ENV{'request.course.sec'}:''))) { |
($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))) { |
$sender.=' <a href="/adm/feedback?replydisc='. |
$sender.=' <a href="/adm/feedback?replydisc='. |
$ressymb.':::'.$idx; |
$escsymb.':::'.$idx; |
if ($newpostsflag) { |
if ($newpostsflag) { |
$sender .= '&previous='.$prevread; |
$sender .= '&previous='.$prevread; |
} |
} |
Line 983 sub build_posting_display {
|
Line 994 sub build_posting_display {
|
} |
} |
if ($outputtarget eq 'export' || $message) { |
if ($outputtarget eq 'export' || $message) { |
my $thisindex=$idx; |
my $thisindex=$idx; |
if ( (($ENV{'environment.threadeddiscussion'}) && ($sortposts eq '')) || ($sortposts eq 'thread') || ($outputtarget eq 'export')) { |
if ( (($env{'environment.threadeddiscussion'}) && ($sortposts eq '')) || ($sortposts eq 'thread') || ($outputtarget eq 'export')) { |
$thisindex=$origindex.substr('00'.$$replies[$$depth[$idx]],-2,2); |
$thisindex=$origindex.substr('00'.$$replies[$$depth[$idx]],-2,2); |
} |
} |
$$alldiscussion{$thisindex}=$idx; |
$$alldiscussion{$thisindex}=$idx; |
Line 1024 sub build_posting_display {
|
Line 1035 sub build_posting_display {
|
my $uname = $contrib{$idx.':sendername'}; |
my $uname = $contrib{$idx.':sendername'}; |
my $udom = $contrib{$idx.':senderdomain'}; |
my $udom = $contrib{$idx.':senderdomain'}; |
my $poster = $uname.':'.$udom; |
my $poster = $uname.':'.$udom; |
if (defined($ENV{'form.totposters'})) { |
if (defined($env{'form.totposters'})) { |
if ($totposters == 0) { |
if ($totposters == 0) { |
$$shown{$idx} = 0; |
$$shown{$idx} = 0; |
} elsif ($totposters > 0) { |
} elsif ($totposters > 0) { |
Line 1079 sub build_posting_display {
|
Line 1090 sub build_posting_display {
|
my @postversions = (); |
my @postversions = (); |
$$discussionitems[$idx] .= &mt('This post has been edited by the author.'); |
$$discussionitems[$idx] .= &mt('This post has been edited by the author.'); |
if ($seeid) { |
if ($seeid) { |
$$discussionitems[$idx] .= ' <a href="/adm/feedback?allversions='.$ressymb.':::'.$idx.'">'.&mt('Display all versions').'</a>'; |
$$discussionitems[$idx] .= ' <a href="/adm/feedback?allversions='.$escsymb.':::'.$idx.'">'.&mt('Display all versions').'</a>'; |
} |
} |
$$discussionitems[$idx].='<br/>'.&mt('Earlier version(s) were posted on: '); |
$$discussionitems[$idx].='<br/>'.&mt('Earlier version(s) were posted on: '); |
if ($contrib{$idx.':history'} =~ m/:/) { |
if ($contrib{$idx.':history'} =~ m/:/) { |
Line 1169 sub get_post_contents {
|
Line 1180 sub get_post_contents {
|
# $$screenname=&Apache::loncommon::screenname( |
# $$screenname=&Apache::loncommon::screenname( |
# $$contrib{$idx.':sendername'}, |
# $$contrib{$idx.':sendername'}, |
# $$contrib{$idx.':senderdomain'}); |
# $$contrib{$idx.':senderdomain'}); |
# $$plainname=&Apache::loncommon::nickname( |
$$plainname=&Apache::loncommon::nickname( |
# $$contrib{$idx.':sendername'}, |
$$contrib{$idx.':sendername'}, |
# $$contrib{$idx.':senderdomain'}); |
$$contrib{$idx.':senderdomain'}); |
($$screenname,$$plainname)=($$contrib{$idx.':screenname'}, |
$$screenname=$$contrib{$idx.':screenname'}; |
$$contrib{$idx.':plainname'}); |
|
my $sender=&Apache::loncommon::aboutmewrapper( |
my $sender=&Apache::loncommon::aboutmewrapper( |
$$plainname, |
$$plainname, |
$$contrib{$idx.':sendername'}, |
$$contrib{$idx.':sendername'}, |
Line 1210 sub get_post_contents {
|
Line 1221 sub get_post_contents {
|
my ($timesent,$attachmsg); |
my ($timesent,$attachmsg); |
my %currattach = (); |
my %currattach = (); |
$timesent = &Apache::lonlocal::locallocaltime($postversions[$i]); |
$timesent = &Apache::lonlocal::locallocaltime($postversions[$i]); |
$$messages{$i}=~s/\n/\<br \/\>/g; |
&newline_to_br(\$messages->{$i}); |
$$messages{$i}=&Apache::lontexconvert::msgtexconverted($$messages{$i}); |
$$messages{$i}=&Apache::lontexconvert::msgtexconverted($$messages{$i}); |
$$subjects{$i}=~s/\n/\<br \/\>/g; |
$$subjects{$i}=~s/\n/\<br \/\>/g; |
$$subjects{$i}=&Apache::lontexconvert::msgtexconverted($$subjects{$i}); |
$$subjects{$i}=&Apache::lontexconvert::msgtexconverted($$subjects{$i}); |
Line 1292 sub replicate_attachments {
|
Line 1303 sub replicate_attachments {
|
|
|
sub mail_screen { |
sub mail_screen { |
my ($r,$feedurl,$options) = @_; |
my ($r,$feedurl,$options) = @_; |
if (exists($ENV{'form.origpage'})) { |
if (exists($env{'form.origpage'})) { |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['subject','comment','currnewattach','addnewattach','deloldattach','delnewattach','timestamp','idx','anondiscuss','discuss']); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['subject','comment','currnewattach','addnewattach','deloldattach','delnewattach','timestamp','idx','anondiscuss','discuss']); |
} |
} |
my $bodytag=&Apache::loncommon::bodytag('Resource Feedback and Discussion', |
my $bodytag=&Apache::loncommon::bodytag('Resource Feedback and Discussion', |
Line 1326 sub mail_screen {
|
Line 1337 sub mail_screen {
|
} |
} |
END |
END |
my $anonscript; |
my $anonscript; |
if (exists($ENV{'form.origpage'})) { |
if (exists($env{'form.origpage'})) { |
$anonscript = (<<END); |
$anonscript = (<<END); |
function setposttype() { |
function setposttype() { |
var anondisc = $ENV{'form.anondiscuss'}; |
var anondisc = $env{'form.anondiscuss'}; |
var disc = $ENV{'form.discuss'}; |
var disc = $env{'form.discuss'}; |
if (anondisc == 1) { |
if (anondisc == 1) { |
document.mailform.anondiscuss.checked = true |
document.mailform.anondiscuss.checked = true |
} |
} |
Line 1347 END
|
Line 1358 END
|
} |
} |
END |
END |
} |
} |
if (($ENV{'form.replydisc'}) || ($ENV{'form.editdisc'})) { |
if (($env{'form.replydisc'}) || ($env{'form.editdisc'})) { |
if ($ENV{'form.replydisc'}) { |
if ($env{'form.replydisc'}) { |
($symb,$idx)=split(/\:\:\:/,$ENV{'form.replydisc'}); |
($symb,$idx)=split(/\:\:\:/,$env{'form.replydisc'}); |
} else { |
} else { |
($symb,$idx)=split(/\:\:\:/,$ENV{'form.editdisc'}); |
($symb,$idx)=split(/\:\:\:/,$env{'form.editdisc'}); |
} |
} |
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
unless (($contrib{'hidden'}=~/\.$idx\./) || ($contrib{'deleted'}=~/\.$idx\./)) { |
unless (($contrib{'hidden'}=~/\.$idx\./) || ($contrib{'deleted'}=~/\.$idx\./)) { |
if ($contrib{$idx.':history'}) { |
if ($contrib{$idx.':history'}) { |
if ($contrib{$idx.':history'} =~ /:/) { |
if ($contrib{$idx.':history'} =~ /:/) { |
Line 1365 END
|
Line 1376 END
|
$numoldver = 1; |
$numoldver = 1; |
} |
} |
} |
} |
if ($ENV{'form.replydisc'}) { |
if ($env{'form.replydisc'}) { |
if ($contrib{$idx.':history'}) { |
if ($contrib{$idx.':history'}) { |
if ($contrib{$idx.':history'} =~ /:/) { |
if ($contrib{$idx.':history'} =~ /:/) { |
my @oldversions = split/:/,$contrib{$idx.':history'}; |
my @oldversions = split/:/,$contrib{$idx.':history'}; |
Line 1380 END
|
Line 1391 END
|
&get_post_versions(\%msgversions,$contrib{$idx.':message'},0,$numoldver); |
&get_post_versions(\%msgversions,$contrib{$idx.':message'},0,$numoldver); |
$message = $msgversions{$numoldver}; |
$message = $msgversions{$numoldver}; |
} |
} |
$message=~s/\n/\<br \/\>/g; |
&newline_to_br(\$message); |
$quote='<blockquote>'.&Apache::lontexconvert::msgtexconverted($message).'</blockquote>'; |
$quote='<blockquote>'.&Apache::lontexconvert::msgtexconverted($message).'</blockquote>'; |
if ($idx > 0) { |
if ($idx > 0) { |
my %subversions = (); |
my %subversions = (); |
Line 1401 END
|
Line 1412 END
|
if (defined($contrib{$idx.':replyto'})) { |
if (defined($contrib{$idx.':replyto'})) { |
$parentmsg = $contrib{$idx.':replyto'}; |
$parentmsg = $contrib{$idx.':replyto'}; |
} |
} |
unless (exists($ENV{'form.origpage'})) { |
unless (exists($env{'form.origpage'})) { |
my $anonflag = 0; |
my $anonflag = 0; |
if ($contrib{$idx.':anonymous'}) { |
if ($contrib{$idx.':anonymous'}) { |
$anonflag = 1; |
$anonflag = 1; |
Line 1423 END
|
Line 1434 END
|
} |
} |
} |
} |
} |
} |
if ($ENV{'form.previous'}) { |
if ($env{'form.previous'}) { |
$prevtag = '<input type="hidden" name="previous" value="'.$ENV{'form.previous'}.'" />'; |
$prevtag = '<input type="hidden" name="previous" value="'.$env{'form.previous'}.'" />'; |
} |
} |
} |
} |
|
|
if ($ENV{'form.origpage'}) { |
if ($env{'form.origpage'}) { |
$subject = &Apache::lonnet::unescape($ENV{'form.subject'}); |
$subject = &Apache::lonnet::unescape($env{'form.subject'}); |
$comment = &Apache::lonnet::unescape($ENV{'form.comment'}); |
$comment = &Apache::lonnet::unescape($env{'form.comment'}); |
&process_attachments(\@currnewattach,\@currdelold,\@keepold); |
&process_attachments(\@currnewattach,\@currdelold,\@keepold); |
} |
} |
my $latexHelp=&Apache::loncommon::helpLatexCheatsheet(); |
my $latexHelp=&Apache::loncommon::helpLatexCheatsheet(); |
Line 1499 enctype="multipart/form-data">
|
Line 1510 enctype="multipart/form-data">
|
$prevtag |
$prevtag |
<input type="hidden" name="postdata" value="$feedurl" /> |
<input type="hidden" name="postdata" value="$feedurl" /> |
END |
END |
if ($ENV{'form.replydisc'}) { |
if ($env{'form.replydisc'}) { |
$r->print(<<END); |
$r->print(<<END); |
<input type="hidden" name="replydisc" value="$ENV{'form.replydisc'}" /> |
<input type="hidden" name="replydisc" value="$env{'form.replydisc'}" /> |
END |
END |
} elsif ($ENV{'form.editdisc'}) { |
} elsif ($env{'form.editdisc'}) { |
$r->print(<<END); |
$r->print(<<END); |
<input type="hidden" name="editdisc" value ="$ENV{'form.editdisc'}" /> |
<input type="hidden" name="editdisc" value ="$env{'form.editdisc'}" /> |
<input type="hidden" name="parentmsg" value ="$parentmsg" /> |
<input type="hidden" name="parentmsg" value ="$parentmsg" /> |
END |
END |
} |
} |
Line 1522 Title: <input type="text" name="subject"
|
Line 1533 Title: <input type="text" name="subject"
|
</textarea></p> |
</textarea></p> |
<p> |
<p> |
END |
END |
if ( ($ENV{'form.editdisc'}) || ($ENV{'form.replydisc'}) ) { |
if ( ($env{'form.editdisc'}) || ($env{'form.replydisc'}) ) { |
if ($ENV{'form.origpage'}) { |
if ($env{'form.origpage'}) { |
foreach (@currnewattach) { |
foreach (@currnewattach) { |
$r->print('<input type="hidden" name="currnewattach" value="'.$_.'" />'."\n"); |
$r->print('<input type="hidden" name="currnewattach" value="'.$_.'" />'."\n"); |
} |
} |
Line 1531 END
|
Line 1542 END
|
$r->print('<input type="hidden" name="deloldattach" value="'.$_.'" />'."\n"); |
$r->print('<input type="hidden" name="deloldattach" value="'.$_.'" />'."\n"); |
} |
} |
} |
} |
if ($ENV{'form.editdisc'}) { |
if ($env{'form.editdisc'}) { |
if ($attachmenturls) { |
if ($attachmenturls) { |
&extract_attachments($attachmenturls,$idx,$numoldver,\$attachmsg,\%attachments,\%currattach,\@currdelold); |
&extract_attachments($attachmenturls,$idx,$numoldver,\$attachmsg,\%attachments,\%currattach,\@currdelold); |
$attachnum = scalar(keys %currattach); |
$attachnum = scalar(keys %currattach); |
Line 1553 END
|
Line 1564 END
|
</p> |
</p> |
</form> |
</form> |
END |
END |
if ($ENV{'form.editdisc'} || $ENV{'form.replydisc'}) { |
if ($env{'form.editdisc'} || $env{'form.replydisc'}) { |
my $now = time; |
my $now = time; |
my $ressymb = $symb; |
my $ressymb = $symb; |
my $postidx = ''; |
my $postidx = ''; |
if ($ENV{'form.editdisc'}) { |
if ($env{'form.editdisc'}) { |
$postidx = $idx; |
$postidx = $idx; |
} |
} |
if (@currnewattach > 0) { |
if (@currnewattach > 0) { |
Line 1599 sub print_display_options {
|
Line 1610 sub print_display_options {
|
|
|
my $function = &Apache::loncommon::get_users_function(); |
my $function = &Apache::loncommon::get_users_function(); |
my $tabcolor = &Apache::loncommon::designparm($function.'.tabbg', |
my $tabcolor = &Apache::loncommon::designparm($function.'.tabbg', |
$ENV{'user.domain'}); |
$env{'user.domain'}); |
my $bodytag=&Apache::loncommon::bodytag('Discussion options', |
my $bodytag=&Apache::loncommon::bodytag('Discussion options', |
'',''); |
'',''); |
|
|
Line 1806 sub print_sortfilter_options {
|
Line 1817 sub print_sortfilter_options {
|
my $numvisible = 5; |
my $numvisible = 5; |
my %sectioncount = (); |
my %sectioncount = (); |
|
|
$numsections = &Apache::loncommon::get_sections($ENV{'course.'.$ENV{'request.course.id'}.'.domain'},$ENV{'course.'.$ENV{'request.course.id'}.'.num'},\%sectioncount); |
$numsections = &Apache::loncommon::get_sections($env{'course.'.$env{'request.course.id'}.'.domain'},$env{'course.'.$env{'request.course.id'}.'.num'},\%sectioncount); |
|
|
if ($ENV{'request.course.sec'} !~ /^\s*$/) { #Restrict section choice to current section |
if ($env{'request.course.sec'} !~ /^\s*$/) { #Restrict section choice to current section |
@sections = ('all',$ENV{'request.course.sec'}); |
@sections = ('all',$env{'request.course.sec'}); |
$numvisible = 2; |
$numvisible = 2; |
} else { |
} else { |
@sections = sort {$a cmp $b} keys(%sectioncount); |
@sections = sort {$a cmp $b} keys(%sectioncount); |
Line 1824 sub print_sortfilter_options {
|
Line 1835 sub print_sortfilter_options {
|
|
|
my $function = &Apache::loncommon::get_users_function(); |
my $function = &Apache::loncommon::get_users_function(); |
my $tabcolor = &Apache::loncommon::designparm($function.'.tabbg', |
my $tabcolor = &Apache::loncommon::designparm($function.'.tabbg', |
$ENV{'user.domain'}); |
$env{'user.domain'}); |
my $bodytag=&Apache::loncommon::bodytag('Discussion options', |
my $bodytag=&Apache::loncommon::bodytag('Discussion options', |
'',''); |
'',''); |
my %lt = &Apache::lonlocal::texthash( |
my %lt = &Apache::lonlocal::texthash( |
Line 1950 END
|
Line 1961 END
|
sub print_showposters { |
sub print_showposters { |
my ($r,$symb,$previous,$feedurl,$sortposts) = @_; |
my ($r,$symb,$previous,$feedurl,$sortposts) = @_; |
|
|
|
&Apache::loncommon::content_type($r,'text/html'); |
|
$r->send_http_header; |
|
|
&Apache::lonenc::check_encrypt(\$symb); |
&Apache::lonenc::check_encrypt(\$symb); |
my $crs='/'.$ENV{'request.course.id'}; |
my $crs='/'.$env{'request.course.id'}; |
if ($ENV{'request.course.sec'}) { |
if ($env{'request.course.sec'}) { |
$crs.='_'.$ENV{'request.course.sec'}; |
$crs.='_'.$env{'request.course.sec'}; |
} |
} |
$crs=~s/\_/\//g; |
$crs=~s/\_/\//g; |
my $seeid=&Apache::lonnet::allowed('rin',$crs); |
my $seeid=&Apache::lonnet::allowed('rin',$crs); |
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
my %namesort = (); |
my %namesort = (); |
my %postcounts = (); |
my %postcounts = (); |
my %lt=&Apache::lonlocal::texthash( |
my %lt=&Apache::lonlocal::texthash( |
Line 2260 sub screen_header {
|
Line 2274 sub screen_header {
|
my ($feedurl,$symb) = @_; |
my ($feedurl,$symb) = @_; |
my $msgoptions=''; |
my $msgoptions=''; |
my $discussoptions=''; |
my $discussoptions=''; |
unless (($ENV{'form.replydisc'}) || ($ENV{'form.editdisc'})) { |
unless (($env{'form.replydisc'}) || ($env{'form.editdisc'})) { |
if (($feedurl=~/^\/res\//) && ($feedurl!~/^\/res\/adm/)) { |
if (($feedurl=~/^\/res\//) && ($feedurl!~/^\/res\/adm/) && ($env{'user.adv'})) { |
$msgoptions= |
$msgoptions= |
'<p><label><input type="checkbox" name="author" /> '. |
'<p><label><input type="checkbox" name="author" /> '. |
&mt('Feedback to resource author').'</label></p>'; |
&mt('Feedback to resource author').'</label></p>'; |
Line 2284 sub screen_header {
|
Line 2298 sub screen_header {
|
'</label></p>'; |
'</label></p>'; |
} |
} |
} |
} |
if ($ENV{'request.course.id'}) { |
if ($env{'request.course.id'}) { |
if (&discussion_open(undef,$symb) && |
if (&discussion_open(undef,$symb) && |
&Apache::lonnet::allowed('pch', |
&Apache::lonnet::allowed('pch', |
$ENV{'request.course.id'}. |
$env{'request.course.id'}. |
($ENV{'request.course.sec'}?'/'.$ENV{'request.course.sec'}:''))) { |
($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))) { |
$discussoptions='<label><input type="checkbox" name="discuss" onClick="this.form.anondiscuss.checked=false;" '. |
$discussoptions='<label><input type="checkbox" name="discuss" onClick="this.form.anondiscuss.checked=false;" '. |
($ENV{'form.replydisc'}?' checked="1"':'').' /> '. |
($env{'form.replydisc'}?' checked="1"':'').' /> '. |
&mt('Contribution to course discussion of resource'); |
&mt('Contribution to course discussion of resource'); |
$discussoptions.='</label><br /><label><input type="checkbox" name="anondiscuss" onClick="this.form.discuss.checked=false;" /> '. |
$discussoptions.='</label><br /><label><input type="checkbox" name="anondiscuss" onClick="this.form.discuss.checked=false;" /> '. |
&mt('Anonymous contribution to course discussion of resource'). |
&mt('Anonymous contribution to course discussion of resource'). |
' <i>('.&mt('name only visible to course faculty').')</i></label>'; |
' <i>('.&mt('name only visible to course faculty').')</i></label> '. |
|
'<a href="/adm/preferences?action=changescreenname">'.&mt('Change Screenname').'</a>'; |
} |
} |
} |
} |
if ($msgoptions) { $msgoptions='<h2><img src="'.&Apache::loncommon::lonhttpdurl('/adm/lonMisc/feedback.gif').'" />'.&mt('Sending Messages').'</h2>'.$msgoptions; } |
if ($msgoptions) { $msgoptions='<h2><img src="'.&Apache::loncommon::lonhttpdurl('/adm/lonMisc/feedback.gif').'" />'.&mt('Sending Messages').'</h2>'.$msgoptions; } |
Line 2322 sub clear_out_html {
|
Line 2337 sub clear_out_html {
|
# Always allow the <m>-tag |
# Always allow the <m>-tag |
my %html=(M=>1); |
my %html=(M=>1); |
# Check if more is allowed |
# Check if more is allowed |
my $cid=$ENV{'request.course.id'}; |
my $cid=$env{'request.course.id'}; |
if (($ENV{"course.$cid.allow_limited_html_in_feedback"} =~ m/yes/i) || |
if (($env{"course.$cid.allow_limited_html_in_feedback"} =~ m/yes/i) || |
($override)) { |
($override)) { |
# allows <B> <I> <P> <A> <LI> <OL> <UL> <EM> <BR> <TT> <STRONG> |
# allows <B> <I> <P> <A> <LI> <OL> <UL> <EM> <BR> <TT> <STRONG> |
# <BLOCKQUOTE> <DIV .*> <DIV> <IMG> <M> <SPAN> <H1> <H2> <H3> <H4> <SUB> |
# <BLOCKQUOTE> <DIV .*> <DIV> <IMG> <M> <SPAN> <H1> <H2> <H3> <H4> <SUB> |
# <SUP> |
# <SUP> |
%html=(B=>1, I=>1, P=>1, A=>1, LI=>1, OL=>1, UL=>1, EM=>1, |
%html=(B=>1, I=>1, P=>1, A=>1, LI=>1, OL=>1, UL=>1, EM=>1, |
BR=>1, TT=>1, STRONG=>1, BLOCKQUOTE=>1, DIV=>1, IMG=>1, |
BR=>1, TT=>1, STRONG=>1, BLOCKQUOTE=>1, DIV=>1, IMG=>1, |
M=>1, SUB=>1, SUP=>1, SPAN=>1, |
M=>1, ALGEBRA=>1, SUB=>1, SUP=>1, SPAN=>1, |
H1=>1, H2=>1, H3=>1, H4=>1, H5=>1); |
H1=>1, H2=>1, H3=>1, H4=>1, H5=>1); |
} |
} |
# Do the substitution of everything that is not explicitly allowed |
# Do the substitution of everything that is not explicitly allowed |
Line 2366 sub secapply {
|
Line 2381 sub secapply {
|
my ($adr,$sections)=($rec=~/^([^\(]+)\(([^\)]+)\)/); |
my ($adr,$sections)=($rec=~/^([^\(]+)\(([^\)]+)\)/); |
if ($sections) { |
if ($sections) { |
foreach (split(/\;/,$sections)) { |
foreach (split(/\;/,$sections)) { |
if (($_ eq $ENV{'request.course.sec'}) || |
if (($_ eq $env{'request.course.sec'}) || |
($defaultflag && ($_ eq '*'))) { |
($defaultflag && ($_ eq '*'))) { |
return $adr; |
return $adr; |
} |
} |
Line 2377 sub secapply {
|
Line 2392 sub secapply {
|
return ''; |
return ''; |
} |
} |
|
|
|
=pod |
|
|
|
=over 4 |
|
|
|
=item * |
|
|
|
decide_receiver($feedurl,$author,$question,$course,$policy,$defaultflag); |
|
|
|
Arguments |
|
$feedurl - /res/ url of resource (only need if $author is true) |
|
$author,$question,$course,$policy - all true/false parameters |
|
if true will attempt to find the addresses of user that should receive |
|
this type of feedback (author - feedback to author of resource $feedurl, |
|
$question 'Resource Content Questions', $course 'Course Content Question', |
|
$policy 'Course Policy') |
|
(Additionally it also checks $env for whether the corresponding form.<name> |
|
element exists, for ease of use in a html response context) |
|
|
|
$defaultflag - (internal should be left blank) if true gather addresses |
|
that aren't for a section even if I have a section |
|
(used for reccursion internally, first we look for |
|
addresses for our specific section then we recurse |
|
and look for non section addresses) |
|
|
|
Returns |
|
$typestyle - string of html text, describing what addresses were found |
|
%to - a hash, which keys are addresses of users to send messages to |
|
the keys will look like name:domain |
|
|
|
=cut |
|
|
sub decide_receiver { |
sub decide_receiver { |
my ($feedurl,$author,$question,$course,$policy,$defaultflag) = @_; |
my ($feedurl,$author,$question,$course,$policy,$defaultflag) = @_; |
my $typestyle=''; |
my $typestyle=''; |
my %to=(); |
my %to=(); |
if ($ENV{'form.author'}||$author) { |
if ($env{'form.author'}||$author) { |
$typestyle.='Submitting as Author Feedback<br>'; |
$typestyle.='Submitting as Author Feedback<br />'; |
$feedurl=~/^\/res\/(\w+)\/(\w+)\//; |
$feedurl=~/^\/res\/(\w+)\/(\w+)\//; |
$to{$2.':'.$1}=1; |
$to{$2.':'.$1}=1; |
} |
} |
if ($ENV{'form.question'}||$question) { |
if ($env{'form.question'}||$question) { |
$typestyle.='Submitting as Question<br>'; |
$typestyle.='Submitting as Question<br />'; |
foreach (split(/\,/, |
foreach (split(/\,/, |
$ENV{'course.'.$ENV{'request.course.id'}.'.question.email'}) |
$env{'course.'.$env{'request.course.id'}.'.question.email'}) |
) { |
) { |
my $rec=&secapply($_,$defaultflag); |
my $rec=&secapply($_,$defaultflag); |
if ($rec) { $to{$rec}=1; } |
if ($rec) { $to{$rec}=1; } |
} |
} |
} |
} |
if ($ENV{'form.course'}||$course) { |
if ($env{'form.course'}||$course) { |
$typestyle.='Submitting as Comment<br />'; |
$typestyle.='Submitting as Comment<br />'; |
foreach (split(/\,/, |
foreach (split(/\,/, |
$ENV{'course.'.$ENV{'request.course.id'}.'.comment.email'}) |
$env{'course.'.$env{'request.course.id'}.'.comment.email'}) |
) { |
) { |
my $rec=&secapply($_,$defaultflag); |
my $rec=&secapply($_,$defaultflag); |
if ($rec) { $to{$rec}=1; } |
if ($rec) { $to{$rec}=1; } |
} |
} |
} |
} |
if ($ENV{'form.policy'}||$policy) { |
if ($env{'form.policy'}||$policy) { |
$typestyle.='Submitting as Policy Feedback<br />'; |
$typestyle.='Submitting as Policy Feedback<br />'; |
foreach (split(/\,/, |
foreach (split(/\,/, |
$ENV{'course.'.$ENV{'request.course.id'}.'.policy.email'}) |
$env{'course.'.$env{'request.course.id'}.'.policy.email'}) |
) { |
) { |
my $rec=&secapply($_,$defaultflag); |
my $rec=&secapply($_,$defaultflag); |
if ($rec) { $to{$rec}=1; } |
if ($rec) { $to{$rec}=1; } |
Line 2467 sub adddiscuss {
|
Line 2513 sub adddiscuss {
|
$realsymb=&Apache::lonnet::symbread($filename); |
$realsymb=&Apache::lonnet::symbread($filename); |
} |
} |
if (&discussion_open(undef,$realsymb) && |
if (&discussion_open(undef,$realsymb) && |
&Apache::lonnet::allowed('pch',$ENV{'request.course.id'}. |
&Apache::lonnet::allowed('pch',$env{'request.course.id'}. |
($ENV{'request.course.sec'}?'/'.$ENV{'request.course.sec'}:''))) { |
($env{'request.course.sec'}?'/'.$env{'request.course.sec'}:''))) { |
|
|
my %contrib=('message' => $email, |
my %contrib=('message' => $email, |
'sendername' => $ENV{'user.name'}, |
'sendername' => $env{'user.name'}, |
'senderdomain' => $ENV{'user.domain'}, |
'senderdomain' => $env{'user.domain'}, |
'screenname' => $ENV{'environment.screenname'}, |
'screenname' => $env{'environment.screenname'}, |
'plainname' => $ENV{'environment.firstname'}.' '. |
'plainname' => $env{'environment.firstname'}.' '. |
$ENV{'environment.middlename'}.' '. |
$env{'environment.middlename'}.' '. |
$ENV{'environment.lastname'}.' '. |
$env{'environment.lastname'}.' '. |
$ENV{'enrironment.generation'}, |
$env{'enrironment.generation'}, |
'attachmenturl'=> $attachmenturl, |
'attachmenturl'=> $attachmenturl, |
'subject' => $subject); |
'subject' => $subject); |
if ($ENV{'form.replydisc'}) { |
if ($env{'form.replydisc'}) { |
$contrib{'replyto'}=(split(/\:\:\:/,$ENV{'form.replydisc'}))[1]; |
$contrib{'replyto'}=(split(/\:\:\:/,$env{'form.replydisc'}))[1]; |
} |
} |
if ($anon) { |
if ($anon) { |
$contrib{'anonymous'}='true'; |
$contrib{'anonymous'}='true'; |
} |
} |
if (($symb) && ($email)) { |
if (($symb) && ($email)) { |
if ($ENV{'form.editdisc'}) { |
if ($env{'form.editdisc'}) { |
my %newcontrib = (); |
my %newcontrib = (); |
$contrib{'ip'}=$ENV{'REMOTE_ADDR'}; |
$contrib{'ip'}=$ENV{'REMOTE_ADDR'}; |
$contrib{'host'}=$Apache::lonnet::perlvar{'lonHostID'}; |
$contrib{'host'}=$Apache::lonnet::perlvar{'lonHostID'}; |
$contrib{'timestamp'} = time; |
$contrib{'timestamp'} = time; |
$contrib{'history'} = ''; |
$contrib{'history'} = ''; |
my $numoldver = 0; |
my $numoldver = 0; |
my ($oldsymb,$oldidx)=split(/\:\:\:/,$ENV{'form.editdisc'}); |
my ($oldsymb,$oldidx)=split(/\:\:\:/,$env{'form.editdisc'}); |
&Apache::lonenc::check_decrypt(\$oldsymb); |
&Apache::lonenc::check_decrypt(\$oldsymb); |
$oldsymb=~s|(bulletin___\d+___)adm/wrapper/|$1|; |
$oldsymb=~s|(bulletin___\d+___)adm/wrapper/|$1|; |
# get timestamp for last post and history |
# get timestamp for last post and history |
my %oldcontrib=&Apache::lonnet::restore($oldsymb,$ENV{'request.course.id'}, |
my %oldcontrib=&Apache::lonnet::restore($oldsymb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
if (defined($oldcontrib{$oldidx.':replyto'})) { |
if (defined($oldcontrib{$oldidx.':replyto'})) { |
$contrib{'replyto'} = $oldcontrib{$oldidx.':replyto'}; |
$contrib{'replyto'} = $oldcontrib{$oldidx.':replyto'}; |
} |
} |
Line 2535 sub adddiscuss {
|
Line 2581 sub adddiscuss {
|
my $key = $oldidx.':'.&Apache::lonnet::escape($oldsymb).':'.$_; |
my $key = $oldidx.':'.&Apache::lonnet::escape($oldsymb).':'.$_; |
$newcontrib{$key} = $contrib{$_}; |
$newcontrib{$key} = $contrib{$_}; |
} |
} |
my $put_reply = &Apache::lonnet::putstore($ENV{'request.course.id'}, |
my $put_reply = &Apache::lonnet::putstore($env{'request.course.id'}, |
\%newcontrib, |
\%newcontrib, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
$status='Editing class discussion'.($anon?' (anonymous)':''); |
$status='Editing class discussion'.($anon?' (anonymous)':''); |
} else { |
} else { |
$status='Adding to class discussion'.($anon?' (anonymous)':'').': '. |
$status='Adding to class discussion'.($anon?' (anonymous)':'').': '. |
&Apache::lonnet::store(\%contrib,$symb,$ENV{'request.course.id'}, |
&Apache::lonnet::store(\%contrib,$symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
} |
} |
my %storenewentry=($symb => time); |
my %storenewentry=($symb => time); |
$status.='<br />'.&mt('Updating discussion time').': '. |
$status.='<br />'.&mt('Updating discussion time').': '. |
&Apache::lonnet::put('discussiontimes',\%storenewentry, |
&Apache::lonnet::put('discussiontimes',\%storenewentry, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
} |
} |
my %record=&Apache::lonnet::restore('_discussion'); |
my %record=&Apache::lonnet::restore('_discussion'); |
my ($temp)=keys %record; |
my ($temp)=keys %record; |
Line 2573 sub show_preview {
|
Line 2619 sub show_preview {
|
my $r=shift; |
my $r=shift; |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
my $message=&clear_out_html($ENV{'form.comment'}); |
my $message=&clear_out_html($env{'form.comment'}); |
$message=~s/\n/\<br \/\>/g; |
&newline_to_br(\$message); |
$message=&Apache::lonspeller::markeduptext($message); |
$message=&Apache::lonspeller::markeduptext($message); |
$message=&Apache::lontexconvert::msgtexconverted($message); |
$message=&Apache::lontexconvert::msgtexconverted($message); |
my $subject=&clear_out_html($ENV{'form.subject'}); |
my $subject=&clear_out_html($env{'form.subject'}); |
$subject=~s/\n/\<br \/\>/g; |
$subject=~s/\n/\<br \/\>/g; |
$subject=&Apache::lontexconvert::msgtexconverted($subject); |
$subject=&Apache::lontexconvert::msgtexconverted($subject); |
my $html=&Apache::lonxml::xmlbegin(); |
my $html=&Apache::lonxml::xmlbegin(); |
Line 2587 sub show_preview {
|
Line 2633 sub show_preview {
|
$message.'</td></tr></table></body></html>'); |
$message.'</td></tr></table></body></html>'); |
} |
} |
|
|
|
|
|
sub newline_to_br { |
|
my ($message)=@_; |
|
my $newmessage; |
|
my $parser=HTML::LCParser->new($message); |
|
while (my $token=$parser->get_token()) { |
|
if ($token->[0] eq 'T') { |
|
my $text=$token->[1]; |
|
$text=~s/\n/\<br \/\>/g; |
|
$newmessage.=$text; |
|
} elsif ($token->[0] eq 'D' || $token->[0] eq 'C') { |
|
$newmessage.=$token->[1]; |
|
} elsif ($token->[0] eq 'PI' || $token->[0] eq 'E') { |
|
$newmessage.=$token->[2]; |
|
} elsif ($token->[0] eq 'S') { |
|
$newmessage.=$token->[4]; |
|
} |
|
|
|
} |
|
$$message=$newmessage; |
|
} |
|
|
sub generate_preview_button { |
sub generate_preview_button { |
|
my ($formname,$fieldname)=@_; |
|
unless ($formname) { $formname='mailform'; } |
|
unless ($fieldname) { $fieldname='comment'; } |
my $pre=&mt("Show Preview and Check Spelling"); |
my $pre=&mt("Show Preview and Check Spelling"); |
return(<<ENDPREVIEW); |
return(<<ENDPREVIEW); |
<form name="preview" action="/adm/feedback?preview=1" method="post" target="preview"> |
<form name="preview" action="/adm/feedback?preview=1" method="post" target="preview"> |
<input type="hidden" name="subject"> |
<input type="hidden" name="subject"> |
<input type="hidden" name="comment" /> |
<input type="hidden" name="comment" /> |
<input type="button" value="$pre" |
<input type="button" value="$pre" |
onClick="if (typeof(document.mailform.onsubmit)=='function') {document.mailform.onsubmit();};this.form.comment.value=document.mailform.comment.value;this.form.subject.value=document.mailform.subject.value;this.form.submit();" /> |
onClick="if (typeof(document.$formname.onsubmit)=='function') {document.$formname.onsubmit();};this.form.comment.value=document.$formname.$fieldname.value;this.form.subject.value=document.$formname.subject.value;this.form.submit();" /> |
</form> |
</form> |
ENDPREVIEW |
ENDPREVIEW |
} |
} |
|
|
sub modify_attachments { |
sub modify_attachments { |
my ($r,$currnewattach,$currdelold,$symb,$idx,$attachmenturls)=@_; |
my ($r,$currnewattach,$currdelold,$symb,$idx,$attachmenturls)=@_; |
my $orig_subject = &Apache::lonnet::unescape($ENV{'form.subject'}); |
my $orig_subject = &Apache::lonnet::unescape($env{'form.subject'}); |
my $subject=&clear_out_html($orig_subject); |
my $subject=&clear_out_html($orig_subject); |
$subject=~s/\n/\<br \/\>/g; |
$subject=~s/\n/\<br \/\>/g; |
$subject=&Apache::lontexconvert::msgtexconverted($subject); |
$subject=&Apache::lontexconvert::msgtexconverted($subject); |
my $timestamp=$ENV{'form.timestamp'}; |
my $timestamp=$env{'form.timestamp'}; |
my $numoldver=$ENV{'form.numoldver'}; |
my $numoldver=$env{'form.numoldver'}; |
my $bodytag=&Apache::loncommon::bodytag('Discussion Post Attachments', |
my $bodytag=&Apache::loncommon::bodytag('Discussion Post Attachments', |
'',''); |
'',''); |
my $msg = ''; |
my $msg = ''; |
Line 2662 END
|
Line 2733 END
|
</td> |
</td> |
</tr> |
</tr> |
</table> |
</table> |
<input type="hidden" name="subject" value="$ENV{'form.subject'}" /> |
<input type="hidden" name="subject" value="$env{'form.subject'}" /> |
<input type="hidden" name="comment" value="$ENV{'form.comment'}" /> |
<input type="hidden" name="comment" value="$env{'form.comment'}" /> |
<input type="hidden" name="timestamp" value="$ENV{'form.timestamp'}" /> |
<input type="hidden" name="timestamp" value="$env{'form.timestamp'}" /> |
<input type="hidden" name="idx" value="$ENV{'form.idx'}" /> |
<input type="hidden" name="idx" value="$env{'form.idx'}" /> |
<input type="hidden" name="numoldver" value="$ENV{'form.numoldver'}" /> |
<input type="hidden" name="numoldver" value="$env{'form.numoldver'}" /> |
<input type="hidden" name="origpage" value="$ENV{'form.origpage'}" /> |
<input type="hidden" name="origpage" value="$env{'form.origpage'}" /> |
<input type="hidden" name="anondiscuss" value="$ENV{'form.anondiscuss'}" /> |
<input type="hidden" name="anondiscuss" value="$env{'form.anondiscuss'}" /> |
<input type="hidden" name="discuss" value="$ENV{'form.discuss'}" /> |
<input type="hidden" name="discuss" value="$env{'form.discuss'}" /> |
END |
END |
foreach (@{$currnewattach}) { |
foreach (@{$currnewattach}) { |
$r->print('<input type="hidden" name="currnewattach" value="'.$_.'" />'."\n"); |
$r->print('<input type="hidden" name="currnewattach" value="'.$_.'" />'."\n"); |
Line 2688 END
|
Line 2759 END
|
|
|
sub process_attachments { |
sub process_attachments { |
my ($currnewattach,$currdelold,$keepold) = @_; |
my ($currnewattach,$currdelold,$keepold) = @_; |
if (exists($ENV{'form.currnewattach'})) { |
|
if (ref($ENV{'form.currnewattach'}) eq 'ARRAY') { |
@{$currnewattach}= |
@{$currnewattach} = @{$ENV{'form.currnewattach'}}; |
&Apache::loncommon::get_env_multiple('form.currnewattach'); |
} else { |
@{$currdelold}= |
$$currnewattach[0] = $ENV{'form.currnewattach'}; |
&Apache::loncommon::get_env_multiple('form.deloldattach'); |
} |
if (exists($env{'form.delnewattach'})) { |
} |
my @currdelnew = |
if (exists($ENV{'form.deloldattach'})) { |
&Apache::loncommon::get_env_multiple('form.delnewattach'); |
if (ref($ENV{'form.deloldattach'}) eq 'ARRAY') { |
|
@{$currdelold} = @{$ENV{'form.deloldattach'}}; |
|
} else { |
|
$$currdelold[0] = $ENV{'form.deloldattach'}; |
|
} |
|
} |
|
if (exists($ENV{'form.delnewattach'})) { |
|
my @currdelnew = (); |
|
my @currnew = (); |
my @currnew = (); |
if (ref($ENV{'form.delnewattach'}) eq 'ARRAY') { |
|
@currdelnew = @{$ENV{'form.delnewattach'}}; |
|
} else { |
|
$currdelnew[0] = $ENV{'form.delnewattach'}; |
|
} |
|
foreach my $newone (@{$currnewattach}) { |
foreach my $newone (@{$currnewattach}) { |
my $delflag = 0; |
my $delflag = 0; |
foreach (@currdelnew) { |
foreach (@currdelnew) { |
Line 2724 sub process_attachments {
|
Line 2782 sub process_attachments {
|
} |
} |
@{$currnewattach} = @currnew; |
@{$currnewattach} = @currnew; |
} |
} |
if (exists($ENV{'form.keepold'})) { |
@{$keepold} = &Apache::loncommon::get_env_multiple('form.keepold'); |
if (ref($ENV{'form.keepold'}) eq 'ARRAY') { |
|
@{$keepold} = @{$ENV{'form.keepold'}}; |
|
} else { |
|
$$keepold[0] = $ENV{'form.keepold'}; |
|
} |
|
} |
|
} |
} |
|
|
sub generate_attachments_button { |
sub generate_attachments_button { |
Line 2752 this.form.submit();" />
|
Line 2804 this.form.submit();" />
|
<input type="hidden" name="timestamp" value="$now" /> |
<input type="hidden" name="timestamp" value="$now" /> |
<input type="hidden" name="subject" /> |
<input type="hidden" name="subject" /> |
<input type="hidden" name="comment" /> |
<input type="hidden" name="comment" /> |
<input type="hidden" name="anondiscuss" value = "0"; |
<input type="hidden" name="anondiscuss" value = "0" /> |
<input type="hidden" name="discuss" value = "0"; |
<input type="hidden" name="discuss" value = "0" /> |
<input type="hidden" name="numoldver" value="$numoldver" /> |
<input type="hidden" name="numoldver" value="$numoldver" /> |
ENDATTACH |
ENDATTACH |
if (defined($deloldattach)) { |
if (defined($deloldattach)) { |
Line 2830 sub construct_attachmenturl {
|
Line 2882 sub construct_attachmenturl {
|
my $newattachmenturl; |
my $newattachmenturl; |
my $startnum = 0; |
my $startnum = 0; |
my $currver = 0; |
my $currver = 0; |
if (($ENV{'form.editdisc'}) && ($idx)) { |
if (($env{'form.editdisc'}) && ($idx)) { |
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
$oldattachmenturl = $contrib{$idx.':attachmenturl'}; |
$oldattachmenturl = $contrib{$idx.':attachmenturl'}; |
if ($contrib{$idx.':history'}) { |
if ($contrib{$idx.':history'}) { |
if ($contrib{$idx.':history'} =~ /:/) { |
if ($contrib{$idx.':history'} =~ /:/) { |
Line 2887 sub has_discussion {
|
Line 2939 sub has_discussion {
|
my @allres=$navmap->retrieveResources(); |
my @allres=$navmap->retrieveResources(); |
foreach my $resource (@allres) { |
foreach my $resource (@allres) { |
if ($resource->hasDiscussion()) { |
if ($resource->hasDiscussion()) { |
my $ressymb; |
my $ressymb = $resource->wrap_symb(); |
if ($resource->symb() =~ m-(___adm/\w+/\w+)/(\d+)/bulletinboard$-) { |
|
$ressymb = 'bulletin___'.$2.$1.'/'.$2.'/bulletinboard'; |
|
} else { |
|
$ressymb = $resource->symb(); |
|
} |
|
push @{$resourcesref}, $ressymb; |
push @{$resourcesref}, $ressymb; |
} |
} |
} |
} |
Line 2939 sub handler {
|
Line 2986 sub handler {
|
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'}, |
['hide','unhide','deldisc','postdata','preview','replydisc','editdisc','cmd','symb','onlyunread','allposts','onlyunmark','previous','markread','markonread','markondisp','toggoff','toggon','modifydisp','changes','navtime','navmaps','navurl','sortposts','applysort','rolefilter','statusfilter','sectionpick','posterlist','userpick','attach','origpage','currnewattach','deloldattach','keepold','allversions','export']); |
['hide','unhide','deldisc','postdata','preview','replydisc','editdisc','cmd','symb','onlyunread','allposts','onlyunmark','previous','markread','markonread','markondisp','toggoff','toggon','modifydisp','changes','navtime','navmaps','navurl','sortposts','applysort','rolefilter','statusfilter','sectionpick','posterlist','userpick','attach','origpage','currnewattach','deloldattach','keepold','allversions','export']); |
|
|
if ($ENV{'form.discsymb'}) { |
if ($env{'form.discsymb'}) { |
my ($symb,$feedurl) = &get_feedurl_and_clean_symb($ENV{'form.discsymb'}); |
my ($symb,$feedurl) = &get_feedurl_and_clean_symb($env{'form.discsymb'}); |
my $readkey = $symb.'_read'; |
my $readkey = $symb.'_read'; |
my $chgcount = 0; |
my $chgcount = 0; |
my %readinghash = &Apache::lonnet::get('nohist_'.$ENV{'request.course.id'}.'_discuss',[$readkey],$ENV{'user.domain'},$ENV{'user.name'}); |
my %readinghash = &Apache::lonnet::get('nohist_'.$env{'request.course.id'}.'_discuss',[$readkey],$env{'user.domain'},$env{'user.name'}); |
foreach my $key (keys %ENV) { |
foreach my $key (keys %env) { |
if ($key =~ m/^form\.postunread_(\d+)/) { |
if ($key =~ m/^form\.postunread_(\d+)/) { |
if ($readinghash{$readkey} =~ /\.$1\./) { |
if ($readinghash{$readkey} =~ /\.$1\./) { |
$readinghash{$readkey} =~ s/\.$1\.//; |
$readinghash{$readkey} =~ s/\.$1\.//; |
Line 2958 sub handler {
|
Line 3005 sub handler {
|
} |
} |
} |
} |
if ($chgcount > 0) { |
if ($chgcount > 0) { |
&Apache::lonnet::put('nohist_'.$ENV{'request.course.id'}.'_discuss', |
&Apache::lonnet::put('nohist_'.$env{'request.course.id'}.'_discuss', |
\%readinghash,$ENV{'user.domain'},$ENV{'user.name'}); |
\%readinghash,$env{'user.domain'},$env{'user.name'}); |
} |
} |
&redirect_back($r,$feedurl,&mt('Marked postings read/unread').'<br />', |
&redirect_back($r,$feedurl,&mt('Marked postings read/unread').'<br />', |
'0','0','',$ENV{'form.previous'},'','','',); |
'0','0','',$env{'form.previous'},'','','',); |
return OK; |
return OK; |
} |
} |
if ($ENV{'form.allversions'}) { |
if ($env{'form.allversions'}) { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
my $html=&Apache::lonxml::xmlbegin(); |
my $html=&Apache::lonxml::xmlbegin(); |
Line 2978 $html
|
Line 3025 $html
|
</head> |
</head> |
$bodytag |
$bodytag |
END |
END |
my $crs='/'.$ENV{'request.course.id'}; |
my $crs='/'.$env{'request.course.id'}; |
if ($ENV{'request.course.sec'}) { |
if ($env{'request.course.sec'}) { |
$crs.='_'.$ENV{'request.course.sec'}; |
$crs.='_'.$env{'request.course.sec'}; |
} |
} |
$crs=~s|_|/|g; |
$crs=~s|_|/|g; |
my $seeid=&Apache::lonnet::allowed('rin',$crs); |
my $seeid=&Apache::lonnet::allowed('rin',$crs); |
my ($symb,$idx)=split(/\:\:\:/,$ENV{'form.allversions'}); |
my ($symb,$idx)=split(/\:\:\:/,$env{'form.allversions'}); |
($symb)=&get_feedurl_and_clean_symb($symb); |
($symb)=&get_feedurl_and_clean_symb($symb); |
if ($idx > 0) { |
if ($idx > 0) { |
my %messages = (); |
my %messages = (); |
Line 2993 END
|
Line 3040 END
|
my %allattachments = (); |
my %allattachments = (); |
my %imsfiles = (); |
my %imsfiles = (); |
my ($screenname,$plainname); |
my ($screenname,$plainname); |
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
$r->print(&get_post_contents(\%contrib,$idx,$seeid,'allversions',\%messages,\%subjects,\%allattachments,\%attachmsgs,\%imsfiles,\$screenname,\$plainname)); |
$r->print(&get_post_contents(\%contrib,$idx,$seeid,'allversions',\%messages,\%subjects,\%allattachments,\%attachmsgs,\%imsfiles,\$screenname,\$plainname)); |
} |
} |
return OK; |
return OK; |
} |
} |
if ($ENV{'form.posterlist'}) { |
if ($env{'form.posterlist'}) { |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($ENV{'form.applysort'}); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($env{'form.applysort'}); |
&print_showposters($r,$symb,$ENV{'form.previous'},$feedurl, |
&print_showposters($r,$symb,$env{'form.previous'},$feedurl, |
$ENV{'form.sortposts'}); |
$env{'form.sortposts'}); |
return OK; |
return OK; |
} |
} |
if ($ENV{'form.userpick'}) { |
if ($env{'form.userpick'}) { |
my @posters = &Apache::loncommon::get_env_multiple('form.stuinfo'); |
my @posters = &Apache::loncommon::get_env_multiple('form.stuinfo'); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($ENV{'form.userpick'}); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($env{'form.userpick'}); |
my $numpicks = @posters; |
my $numpicks = @posters; |
my %discinfo; |
my %discinfo; |
$discinfo{$symb.'_userpick'} = join('&',@posters); |
$discinfo{$symb.'_userpick'} = join('&',@posters); |
&Apache::lonnet::put('nohist_'.$ENV{'request.course.id'}.'_discuss', |
&Apache::lonnet::put('nohist_'.$env{'request.course.id'}.'_discuss', |
\%discinfo,$ENV{'user.domain'},$ENV{'user.name'}); |
\%discinfo,$env{'user.domain'},$env{'user.name'}); |
&redirect_back($r,$feedurl,&mt('Changed sort/filter').'<br />','0','0', |
&redirect_back($r,$feedurl,&mt('Changed sort/filter').'<br />','0','0', |
'',$ENV{'form.previous'},$ENV{'form.sortposts'},'','','', |
'',$env{'form.previous'},$env{'form.sortposts'},'','','', |
$numpicks); |
$numpicks); |
return OK; |
return OK; |
} |
} |
if ($ENV{'form.applysort'}) { |
if ($env{'form.applysort'}) { |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($ENV{'form.applysort'}); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($env{'form.applysort'}); |
&redirect_back($r,$feedurl,&mt('Changed sort/filter').'<br />','0','0', |
&redirect_back($r,$feedurl,&mt('Changed sort/filter').'<br />','0','0', |
'',$ENV{'form.previous'},$ENV{'form.sortposts'}, |
'',$env{'form.previous'},$env{'form.sortposts'}, |
$ENV{'form.rolefilter'},$ENV{'form.statusfilter'}, |
$env{'form.rolefilter'},$env{'form.statusfilter'}, |
$ENV{'form.sectionpick'}); |
$env{'form.sectionpick'}); |
return OK; |
return OK; |
} elsif ($ENV{'form.cmd'} eq 'sortfilter') { |
} elsif ($env{'form.cmd'} eq 'sortfilter') { |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($ENV{'form.symb'}); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($env{'form.symb'}); |
&print_sortfilter_options($r,$symb,$ENV{'form.previous'},$feedurl); |
&print_sortfilter_options($r,$symb,$env{'form.previous'},$feedurl); |
return OK; |
return OK; |
} elsif ($ENV{'form.navtime'}) { |
} elsif ($env{'form.navtime'}) { |
my %discinfo = (); |
my %discinfo = (); |
my @resources = (); |
my @resources = (); |
if (defined($ENV{'form.navmaps'})) { |
if (defined($env{'form.navmaps'})) { |
if ($ENV{'form.navmaps'} =~ /:/) { |
if ($env{'form.navmaps'} =~ /:/) { |
@resources = split/:/,$ENV{'form.navmaps'}; |
@resources = split/:/,$env{'form.navmaps'}; |
} else { |
} else { |
@resources = ("$ENV{'form.navmaps'}"); |
@resources = ("$env{'form.navmaps'}"); |
} |
} |
} else { |
} else { |
&has_discussion(\@resources); |
&has_discussion(\@resources); |
} |
} |
my $numitems = @resources; |
my $numitems = @resources; |
my $feedurl = '/adm/navmaps'; |
my $feedurl = '/adm/navmaps'; |
if ($ENV{'form.navurl'}) { $feedurl .= '?'.$ENV{'form.navurl'}; } |
if ($env{'form.navurl'}) { $feedurl .= '?'.$env{'form.navurl'}; } |
my %lt = &Apache::lonlocal::texthash( |
my %lt = &Apache::lonlocal::texthash( |
'mnpa' => 'Marked "New" posts as read in a total of', |
'mnpa' => 'Marked "New" posts as read in a total of', |
'robb' => 'resources/bulletin boards.', |
'robb' => 'resources/bulletin boards.', |
'twnp' => 'There are currently no resources or bulletin boards with unread discussion postings.' |
'twnp' => 'There are currently no resources or bulletin boards with unread discussion postings.' |
); |
); |
foreach (@resources) { |
foreach (@resources) { |
# backward compatibility (bulletin boards used to be 'wrapped') |
|
my $ressymb=$_; |
my $ressymb=$_; |
&Apache::lonenc::check_decrypt(\$ressymb); |
&Apache::lonenc::check_decrypt(\$ressymb); |
if ($ressymb =~ m/bulletin___\d+___/) { |
|
unless ($ressymb =~ m|bulletin___\d+___adm/wrapper|) { |
|
$ressymb=~s|(bulletin___\d+___)|$1adm/wrapper/|; |
|
} |
|
} |
|
my $lastkey = $ressymb.'_lastread'; |
my $lastkey = $ressymb.'_lastread'; |
$discinfo{$lastkey} = $ENV{'form.navtime'}; |
$discinfo{$lastkey} = $env{'form.navtime'}; |
} |
} |
my $textline = "<b>$lt{'mnpa'} $numitems $lt{'robb'}</b>"; |
my $textline = "<b>$lt{'mnpa'} $numitems $lt{'robb'}</b>"; |
if ($numitems > 0) { |
if ($numitems > 0) { |
&Apache::lonnet::put('nohist_'.$ENV{'request.course.id'}.'_discuss', |
&Apache::lonnet::put('nohist_'.$env{'request.course.id'}.'_discuss', |
\%discinfo,$ENV{'user.domain'},$ENV{'user.name'}); |
\%discinfo,$env{'user.domain'},$env{'user.name'}); |
} else { |
} else { |
$textline = "<b>$lt{'twnp'}</b>"; |
$textline = "<b>$lt{'twnp'}</b>"; |
} |
} |
Line 3090 $textline
|
Line 3131 $textline
|
</html> |
</html> |
ENDREDIR |
ENDREDIR |
return OK; |
return OK; |
} elsif ($ENV{'form.modifydisp'}) { |
} elsif ($env{'form.modifydisp'}) { |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($ENV{'form.modifydisp'}); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($env{'form.modifydisp'}); |
my ($dispchgA,$dispchgB,$markchg,$toggchg) = |
my ($dispchgA,$dispchgB,$markchg,$toggchg) = |
split(/_/,$ENV{'form.changes'}); |
split(/_/,$env{'form.changes'}); |
&print_display_options($r,$symb,$ENV{'form.previous'},$dispchgA, |
&print_display_options($r,$symb,$env{'form.previous'},$dispchgA, |
$dispchgB,$markchg,$toggchg,$feedurl); |
$dispchgB,$markchg,$toggchg,$feedurl); |
return OK; |
return OK; |
} elsif ($ENV{'form.markondisp'} || $ENV{'form.markonread'} || |
} elsif ($env{'form.markondisp'} || $env{'form.markonread'} || |
$ENV{'form.allposts'} || $ENV{'form.onlyunread'} || |
$env{'form.allposts'} || $env{'form.onlyunread'} || |
$ENV{'form.onlyunmark'} || $ENV{'form.toggoff'} || |
$env{'form.onlyunmark'} || $env{'form.toggoff'} || |
$ENV{'form.toggon'} || $ENV{'form.markread'}) { |
$env{'form.toggon'} || $env{'form.markread'}) { |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($ENV{'form.symb'}); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($env{'form.symb'}); |
my %discinfo; |
my %discinfo; |
# ------------------------ Modify setting for read/unread toggle for each post |
# ------------------------ Modify setting for read/unread toggle for each post |
if ($ENV{'form.toggoff'}) { $discinfo{$symb.'_readtoggle'}=0; } |
if ($env{'form.toggoff'}) { $discinfo{$symb.'_readtoggle'}=0; } |
if ($ENV{'form.toggon'}) { $discinfo{$symb.'_readtoggle'}=1; } |
if ($env{'form.toggon'}) { $discinfo{$symb.'_readtoggle'}=1; } |
# --------- Modify setting for identification of 'NEW' posts in this discussion |
# --------- Modify setting for identification of 'NEW' posts in this discussion |
if ($ENV{'form.markondisp'}) { |
if ($env{'form.markondisp'}) { |
$discinfo{$symb.'_lastread'} = time; |
$discinfo{$symb.'_lastread'} = time; |
$discinfo{$symb.'_markondisp'} = 1; |
$discinfo{$symb.'_markondisp'} = 1; |
} |
} |
if ($ENV{'form.markonread'}) { |
if ($env{'form.markonread'}) { |
if ( $ENV{'form.previous'} > 0 ) { |
if ( $env{'form.previous'} > 0 ) { |
$discinfo{$symb.'_lastread'} = $ENV{'form.previous'}; |
$discinfo{$symb.'_lastread'} = $env{'form.previous'}; |
} |
} |
$discinfo{$symb.'_markondisp'} = 0; |
$discinfo{$symb.'_markondisp'} = 0; |
} |
} |
# --------------------------------- Modify display setting for this discussion |
# --------------------------------- Modify display setting for this discussion |
if ($ENV{'form.allposts'}) { |
if ($env{'form.allposts'}) { |
$discinfo{$symb.'_showonlyunread'} = 0; |
$discinfo{$symb.'_showonlyunread'} = 0; |
$discinfo{$symb.'_showonlyunmark'} = 0; |
$discinfo{$symb.'_showonlyunmark'} = 0; |
} |
} |
if ($ENV{'form.onlyunread'}) { $discinfo{$symb.'_showonlyunread'} = 1; } |
if ($env{'form.onlyunread'}) { $discinfo{$symb.'_showonlyunread'} = 1; } |
if ($ENV{'form.onlyunmark'}) { $discinfo{$symb.'_showonlyunmark'} = 1; } |
if ($env{'form.onlyunmark'}) { $discinfo{$symb.'_showonlyunmark'} = 1; } |
# ----------------------------------------------------- Mark new posts not NEW |
# ----------------------------------------------------- Mark new posts not NEW |
if ($ENV{'form.markread'}) { $discinfo{$symb.'_lastread'} = time; } |
if ($env{'form.markread'}) { $discinfo{$symb.'_lastread'} = time; } |
&Apache::lonnet::put('nohist_'.$ENV{'request.course.id'}.'_discuss', |
&Apache::lonnet::put('nohist_'.$env{'request.course.id'}.'_discuss', |
\%discinfo,$ENV{'user.domain'},$ENV{'user.name'}); |
\%discinfo,$env{'user.domain'},$env{'user.name'}); |
my $previous=$ENV{'form.previous'}; |
my $previous=$env{'form.previous'}; |
if ($ENV{'form.markondisp'}) { $previous=undef; } |
if ($env{'form.markondisp'}) { $previous=undef; } |
&redirect_back($r,$feedurl,&mt('Changed display status').'<br />', |
&redirect_back($r,$feedurl,&mt('Changed display status').'<br />', |
'0','0','',$previous); |
'0','0','',$previous); |
return OK; |
return OK; |
} elsif (($ENV{'form.hide'}) || ($ENV{'form.unhide'})) { |
} elsif (($env{'form.hide'}) || ($env{'form.unhide'})) { |
# ----------------------------------------------------------------- Hide/unhide |
# ----------------------------------------------------------------- Hide/unhide |
my $entry=$ENV{'form.hide'}?$ENV{'form.hide'}:$ENV{'form.unhide'}; |
my $entry=$env{'form.hide'}?$env{'form.hide'}:$env{'form.unhide'}; |
my ($symb,$idx)=split(/\:\:\:/,$entry); |
my ($symb,$idx)=split(/\:\:\:/,$entry); |
($symb,my $feedurl)=&get_feedurl_and_clean_symb($symb); |
($symb,my $feedurl)=&get_feedurl_and_clean_symb($symb); |
|
|
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
|
|
my $currenthidden=$contrib{'hidden'}; |
my $currenthidden=$contrib{'hidden'}; |
my $currentstudenthidden=$contrib{'studenthidden'}; |
my $currentstudenthidden=$contrib{'studenthidden'}; |
|
|
my $crs='/'.$ENV{'request.course.id'}; |
my $crs='/'.$env{'request.course.id'}; |
if ($ENV{'request.course.sec'}) { |
if ($env{'request.course.sec'}) { |
$crs.='_'.$ENV{'request.course.sec'}; |
$crs.='_'.$env{'request.course.sec'}; |
} |
} |
$crs=~s/\_/\//g; |
$crs=~s/\_/\//g; |
my $seeid=&Apache::lonnet::allowed('rin',$crs); |
my $seeid=&Apache::lonnet::allowed('rin',$crs); |
|
|
if ($ENV{'form.hide'}) { |
if ($env{'form.hide'}) { |
$currenthidden.='.'.$idx.'.'; |
$currenthidden.='.'.$idx.'.'; |
unless ($seeid) { |
unless ($seeid) { |
$currentstudenthidden.='.'.$idx.'.'; |
$currentstudenthidden.='.'.$idx.'.'; |
Line 3162 ENDREDIR
|
Line 3203 ENDREDIR
|
$currenthidden=~s/\.$idx\.//g; |
$currenthidden=~s/\.$idx\.//g; |
} |
} |
my %newhash=('hidden' => $currenthidden); |
my %newhash=('hidden' => $currenthidden); |
if ( ($ENV{'form.hide'}) && (!$seeid) ) { |
if ( ($env{'form.hide'}) && (!$seeid) ) { |
$newhash{'studenthidden'} = $currentstudenthidden; |
$newhash{'studenthidden'} = $currentstudenthidden; |
} |
} |
|
|
&Apache::lonnet::store(\%newhash,$symb,$ENV{'request.course.id'}, |
&Apache::lonnet::store(\%newhash,$symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
|
|
&redirect_back($r,$feedurl,&mt('Changed discussion status').'<br />', |
&redirect_back($r,$feedurl,&mt('Changed discussion status').'<br />', |
'0','0','',$ENV{'form.previous'}); |
'0','0','',$env{'form.previous'}); |
return OK; |
return OK; |
} elsif ($ENV{'form.cmd'}=~/^(threadedoff|threadedon)$/) { |
} elsif ($env{'form.cmd'}=~/^(threadedoff|threadedon)$/) { |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($ENV{'form.symb'}); |
my ($symb,$feedurl)=&get_feedurl_and_clean_symb($env{'form.symb'}); |
if ($ENV{'form.cmd'} eq 'threadedon') { |
if ($env{'form.cmd'} eq 'threadedon') { |
&Apache::lonnet::put('environment',{'threadeddiscussion' => 'on'}); |
&Apache::lonnet::put('environment',{'threadeddiscussion' => 'on'}); |
&Apache::lonnet::appenv('environment.threadeddiscussion' => 'on'); |
&Apache::lonnet::appenv('environment.threadeddiscussion' => 'on'); |
} else { |
} else { |
Line 3183 ENDREDIR
|
Line 3224 ENDREDIR
|
&Apache::lonnet::delenv('environment\.threadeddiscussion'); |
&Apache::lonnet::delenv('environment\.threadeddiscussion'); |
} |
} |
&redirect_back($r,$feedurl,&mt('Changed discussion view mode').'<br />', |
&redirect_back($r,$feedurl,&mt('Changed discussion view mode').'<br />', |
'0','0','',$ENV{'form.previous'}); |
'0','0','',$env{'form.previous'}); |
return OK; |
return OK; |
} elsif ($ENV{'form.deldisc'}) { |
} elsif ($env{'form.deldisc'}) { |
# --------------------------------------------------------------- Hide for good |
# --------------------------------------------------------------- Hide for good |
my ($symb,$idx)=split(/\:\:\:/,$ENV{'form.deldisc'}); |
my ($symb,$idx)=split(/\:\:\:/,$env{'form.deldisc'}); |
($symb,my $feedurl)=&get_feedurl_and_clean_symb($symb); |
($symb,my $feedurl)=&get_feedurl_and_clean_symb($symb); |
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
my %newhash=('deleted' => $contrib{'deleted'}.".$idx."); |
my %newhash=('deleted' => $contrib{'deleted'}.".$idx."); |
&Apache::lonnet::store(\%newhash,$symb,$ENV{'request.course.id'}, |
&Apache::lonnet::store(\%newhash,$symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
&redirect_back($r,$feedurl,&mt('Changed discussion status').'<br />', |
&redirect_back($r,$feedurl,&mt('Changed discussion status').'<br />', |
'0','0','',$ENV{'form.previous'}); |
'0','0','',$env{'form.previous'}); |
return OK; |
return OK; |
} elsif ($ENV{'form.preview'}) { |
} elsif ($env{'form.preview'}) { |
# -------------------------------------------------------- User wants a preview |
# -------------------------------------------------------- User wants a preview |
&show_preview($r); |
&show_preview($r); |
return OK; |
return OK; |
} elsif ($ENV{'form.attach'}) { |
} elsif ($env{'form.attach'}) { |
# -------------------------------------------------------- Work on attachments |
# -------------------------------------------------------- Work on attachments |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['subject','comment','addnewattach','delnewattach','timestamp','numoldver','idx','anondiscuss','discuss']); |
&Apache::loncommon::get_unprocessed_cgi($ENV{'QUERY_STRING'},['subject','comment','addnewattach','delnewattach','timestamp','numoldver','idx','anondiscuss','discuss']); |
my (@currnewattach,@currdelold,@keepold); |
my (@currnewattach,@currdelold,@keepold); |
&process_attachments(\@currnewattach,\@currdelold,\@keepold); |
&process_attachments(\@currnewattach,\@currdelold,\@keepold); |
if (exists($ENV{'form.addnewattach.filename'})) { |
if (exists($env{'form.addnewattach.filename'})) { |
unless (length($ENV{'form.addnewattach'})>131072) { |
unless (length($env{'form.addnewattach'})>131072) { |
my $subdir = 'feedback/'.$ENV{'form.timestamp'}; |
my $subdir = 'feedback/'.$env{'form.timestamp'}; |
my $newattachment=&Apache::lonnet::userfileupload('addnewattach',undef,$subdir); |
my $newattachment=&Apache::lonnet::userfileupload('addnewattach',undef,$subdir); |
push @currnewattach, $newattachment; |
push @currnewattach, $newattachment; |
} |
} |
} |
} |
my $attachmenturls; |
my $attachmenturls; |
my ($symb) = &get_feedurl_and_clean_symb($ENV{'form.attach'}); |
my ($symb) = &get_feedurl_and_clean_symb($env{'form.attach'}); |
my $idx = $ENV{'form.idx'}; |
my $idx = $env{'form.idx'}; |
if ($idx) { |
if ($idx) { |
my %contrib=&Apache::lonnet::restore($symb,$ENV{'request.course.id'}, |
my %contrib=&Apache::lonnet::restore($symb,$env{'request.course.id'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}, |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
$ENV{'course.'.$ENV{'request.course.id'}.'.num'}); |
$env{'course.'.$env{'request.course.id'}.'.num'}); |
$attachmenturls = $contrib{$idx.':attachmenturl'}; |
$attachmenturls = $contrib{$idx.':attachmenturl'}; |
} |
} |
&modify_attachments($r,\@currnewattach,\@currdelold,$symb,$idx, |
&modify_attachments($r,\@currnewattach,\@currdelold,$symb,$idx, |
$attachmenturls); |
$attachmenturls); |
return OK; |
return OK; |
} elsif ($ENV{'form.export'}) { |
} elsif ($env{'form.export'}) { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
my ($symb,$feedurl) = &get_feedurl_and_clean_symb($ENV{'form.export'}); |
my ($symb,$feedurl) = &get_feedurl_and_clean_symb($env{'form.export'}); |
my $mode='board'; |
my $mode='board'; |
my $status='OPEN'; |
my $status='OPEN'; |
my $previous=$ENV{'form.previous'}; |
my $previous=$env{'form.previous'}; |
if ($feedurl =~ /\.(problem|exam|quiz|assess|survey|form|library)$/) { |
if ($feedurl =~ /\.(problem|exam|quiz|assess|survey|form|library|task)$/) { |
$mode='problem'; |
$mode='problem'; |
$status=$Apache::inputtags::status[-1]; |
$status=$Apache::inputtags::status[-1]; |
} |
} |
Line 3246 ENDREDIR
|
Line 3287 ENDREDIR
|
return OK; |
return OK; |
} else { |
} else { |
# ------------------------------------------------------------- Normal feedback |
# ------------------------------------------------------------- Normal feedback |
my $feedurl=$ENV{'form.postdata'}; |
my $feedurl=$env{'form.postdata'}; |
$feedurl=~s/^http\:\/\///; |
$feedurl=~s/^http\:\/\///; |
$feedurl=~s/^$ENV{'SERVER_NAME'}//; |
$feedurl=~s/^$ENV{'SERVER_NAME'}//; |
$feedurl=~s/^$ENV{'HTTP_HOST'}//; |
$feedurl=~s/^$ENV{'HTTP_HOST'}//; |
$feedurl=~s/\?.+$//; |
$feedurl=~s/\?.+$//; |
|
|
my $symb; |
my $symb; |
if ($ENV{'form.replydisc'}) { |
if ($env{'form.replydisc'}) { |
$symb=(split(/\:\:\:/,$ENV{'form.replydisc'}))[0]; |
$symb=(split(/\:\:\:/,$env{'form.replydisc'}))[0]; |
my ($map,$id,$url)=&Apache::lonnet::decode_symb($symb); |
my ($map,$id,$url)=&Apache::lonnet::decode_symb($symb); |
$feedurl=&Apache::lonnet::clutter($url); |
$feedurl=&Apache::lonnet::clutter($url); |
} elsif ($ENV{'form.editdisc'}) { |
} elsif ($env{'form.editdisc'}) { |
$symb=(split(/\:\:\:/,$ENV{'form.editdisc'}))[0]; |
$symb=(split(/\:\:\:/,$env{'form.editdisc'}))[0]; |
my ($map,$id,$url)=&Apache::lonnet::decode_symb($symb); |
my ($map,$id,$url)=&Apache::lonnet::decode_symb($symb); |
$feedurl=&Apache::lonnet::clutter($url); |
$feedurl=&Apache::lonnet::clutter($url); |
} elsif ($ENV{'form.origpage'}) { |
} elsif ($env{'form.origpage'}) { |
$symb=""; |
$symb=""; |
} else { |
} else { |
$symb=&Apache::lonnet::symbread($feedurl); |
$symb=&Apache::lonnet::symbread($feedurl); |
} |
} |
unless ($symb) { |
unless ($symb) { |
$symb=$ENV{'form.symb'}; |
$symb=$env{'form.symb'}; |
if ($symb) { |
if ($symb) { |
my ($map,$id,$url)=&Apache::lonnet::decode_symb($symb); |
my ($map,$id,$url)=&Apache::lonnet::decode_symb($symb); |
$feedurl=&Apache::lonnet::clutter($url); |
$feedurl=&Apache::lonnet::clutter($url); |
Line 3275 ENDREDIR
|
Line 3316 ENDREDIR
|
} |
} |
&Apache::lonenc::check_decrypt(\$symb); |
&Apache::lonenc::check_decrypt(\$symb); |
my $goahead=1; |
my $goahead=1; |
if ($feedurl=~/\.(problem|exam|quiz|assess|survey|form)$/) { |
if ($feedurl=~/\.(problem|exam|quiz|assess|survey|form|task)$/) { |
unless ($symb) { $goahead=0; } |
unless ($symb) { $goahead=0; } |
} |
} |
# backward compatibility (bulletin boards used to be 'wrapped') |
# backward compatibility (bulletin boards used to be 'wrapped') |
if ($feedurl=~m|^/adm/wrapper/adm/.*/bulletinboard$|) { |
&dewrapper(\$feedurl); |
$feedurl=~s|^/adm/wrapper||; |
|
} |
|
if (!$goahead) { |
if (!$goahead) { |
# Ambiguous Problem Resource |
# Ambiguous Problem Resource |
$r->internal_redirect('/adm/ambiguous'); |
$r->internal_redirect('/adm/ambiguous'); |
Line 3293 ENDREDIR
|
Line 3332 ENDREDIR
|
($feedurl=~m:^/res:) && ($feedurl!~m:^/res/adm:) |
($feedurl=~m:^/res:) && ($feedurl!~m:^/res/adm:) |
) |
) |
|| |
|| |
($ENV{'request.course.id'} && ($feedurl!~m:^/adm:)) |
($env{'request.course.id'} && ($feedurl!~m:^/adm:)) |
|| |
|| |
($ENV{'request.course.id'} && ($symb=~/^bulletin\_\_\_/)) |
($env{'request.course.id'} && ($symb=~/^bulletin\_\_\_/)) |
) { |
) { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
Line 3303 ENDREDIR
|
Line 3342 ENDREDIR
|
&no_redirect_back($r,$feedurl); |
&no_redirect_back($r,$feedurl); |
} |
} |
# --------------------------------------------------- Print login screen header |
# --------------------------------------------------- Print login screen header |
unless ($ENV{'form.sendit'}) { |
unless ($env{'form.sendit'}) { |
&Apache::loncommon::content_type($r,'text/html'); |
&Apache::loncommon::content_type($r,'text/html'); |
$r->send_http_header; |
$r->send_http_header; |
my $options=&screen_header($feedurl,$symb); |
my $options=&screen_header($feedurl,$symb); |
Line 3317 ENDREDIR
|
Line 3356 ENDREDIR
|
|
|
# Get previous user input |
# Get previous user input |
my $prevattempts=&Apache::loncommon::get_previous_attempt( |
my $prevattempts=&Apache::loncommon::get_previous_attempt( |
$symb,$ENV{'user.name'},$ENV{'user.domain'}, |
$symb,$env{'user.name'},$env{'user.domain'}, |
$ENV{'request.course.id'}); |
$env{'request.course.id'}); |
|
|
# Get output from resource |
# Get output from resource |
my $usersaw=&resource_output($feedurl); |
my $usersaw=&resource_output($feedurl); |
Line 3326 ENDREDIR
|
Line 3365 ENDREDIR
|
# Get resource answer (need to allow student to view grades for this to work) |
# Get resource answer (need to allow student to view grades for this to work) |
&Apache::lonnet::appenv(('allowed.vgr'=>'F')); |
&Apache::lonnet::appenv(('allowed.vgr'=>'F')); |
my $useranswer=&Apache::loncommon::get_student_answers( |
my $useranswer=&Apache::loncommon::get_student_answers( |
$symb,$ENV{'user.name'},$ENV{'user.domain'}, |
$symb,$env{'user.name'},$env{'user.domain'}, |
$ENV{'request.course.id'}); |
$env{'request.course.id'}); |
&Apache::lonnet::delenv('allowed.vgr'); |
&Apache::lonnet::delenv('allowed.vgr'); |
# Get attachments, if any, and not too large |
# Get attachments, if any, and not too large |
my $attachmenturl=''; |
my $attachmenturl=''; |
if (($ENV{'form.origpage'}) || ($ENV{'form.editdisc'}) || |
if (($env{'form.origpage'}) || ($env{'form.editdisc'}) || |
($ENV{'form.replydisc'})) { |
($env{'form.replydisc'})) { |
my ($symb,$idx); |
my ($symb,$idx); |
if ($ENV{'form.replydisc'}) { |
if ($env{'form.replydisc'}) { |
($symb,$idx)=split(/\:\:\:/,$ENV{'form.replydisc'}); |
($symb,$idx)=split(/\:\:\:/,$env{'form.replydisc'}); |
} elsif ($ENV{'form.editdisc'}) { |
} elsif ($env{'form.editdisc'}) { |
($symb,$idx)=split(/\:\:\:/,$ENV{'form.editdisc'}); |
($symb,$idx)=split(/\:\:\:/,$env{'form.editdisc'}); |
} elsif ($ENV{'form.origpage'}) { |
} elsif ($env{'form.origpage'}) { |
$symb = $ENV{'form.symb'}; |
$symb = $env{'form.symb'}; |
} |
} |
&Apache::lonenc::check_decrypt(\$symb); |
&Apache::lonenc::check_decrypt(\$symb); |
my @currnewattach = (); |
my @currnewattach = (); |
Line 3348 ENDREDIR
|
Line 3387 ENDREDIR
|
&process_attachments(\@currnewattach,\@deloldattach,\@keepold); |
&process_attachments(\@currnewattach,\@deloldattach,\@keepold); |
$symb=~s|(bulletin___\d+___)adm/wrapper/|$1|; |
$symb=~s|(bulletin___\d+___)adm/wrapper/|$1|; |
$attachmenturl=&construct_attachmenturl(\@currnewattach,\@keepold,$symb,$idx); |
$attachmenturl=&construct_attachmenturl(\@currnewattach,\@keepold,$symb,$idx); |
} elsif ($ENV{'form.attachment.filename'}) { |
} elsif ($env{'form.attachment.filename'}) { |
unless (length($ENV{'form.attachment'})>131072) { |
unless (length($env{'form.attachment'})>131072) { |
$attachmenturl=&Apache::lonnet::userfileupload('attachment',undef,'feedback'); |
$attachmenturl=&Apache::lonnet::userfileupload('attachment',undef,'feedback'); |
} |
} |
} |
} |
# Filter HTML out of message (could be nasty) |
# Filter HTML out of message (could be nasty) |
my $message=&clear_out_html($ENV{'form.comment'}); |
my $message=&clear_out_html($env{'form.comment'}); |
|
|
# Assemble email |
# Assemble email |
my ($email,$citations)=&assemble_email($feedurl,$message,$prevattempts, |
my ($email,$citations)=&assemble_email($feedurl,$message,$prevattempts, |
Line 3370 ENDREDIR
|
Line 3409 ENDREDIR
|
# Discussion? Store that. |
# Discussion? Store that. |
|
|
my $numpost=0; |
my $numpost=0; |
if ($ENV{'form.discuss'} || $ENV{'form.anondiscuss'}) { |
if ($env{'form.discuss'} || $env{'form.anondiscuss'}) { |
my $subject = &clear_out_html($ENV{'form.subject'}); |
my $subject = &clear_out_html($env{'form.subject'}); |
my $anonmode=(defined($ENV{'form.anondiscuss'})); |
my $anonmode=(defined($env{'form.anondiscuss'})); |
$typestyle.=&adddiscuss($symb,$message,$anonmode,$attachmenturl, |
$typestyle.=&adddiscuss($symb,$message,$anonmode,$attachmenturl, |
$subject); |
$subject); |
$numpost++; |
$numpost++; |
} |
} |
|
|
# Receipt screen and redirect back to where came from |
# Receipt screen and redirect back to where came from |
&redirect_back($r,$feedurl,$typestyle,$numsent,$numpost,$status,$ENV{'form.previous'}); |
&redirect_back($r,$feedurl,$typestyle,$numsent,$numpost,$status,$env{'form.previous'}); |
} |
} |
return OK; |
return OK; |
} |
} |