version 1.28, 2006/05/23 21:42:09
|
version 1.35.2.2, 2006/06/30 02:06:15
|
Line 126 use Apache::loncommunicate;
|
Line 126 use Apache::loncommunicate;
|
use Apache::lonfeedback; |
use Apache::lonfeedback; |
use Apache::lonrss(); |
use Apache::lonrss(); |
use Apache::lonselstudent(); |
use Apache::lonselstudent(); |
|
use lib '/home/httpd/lib/perl/'; |
|
use LONCAPA; |
|
|
# Querystring component with sorting type |
# Querystring component with sorting type |
my $sqs; |
my $sqs; |
Line 215 sub movemsg {
|
Line 217 sub movemsg {
|
# Copy message |
# Copy message |
my %message=&Apache::lonnet::get('nohist_email'.$srcsuffix,[$msgid]); |
my %message=&Apache::lonnet::get('nohist_email'.$srcsuffix,[$msgid]); |
if (!exists($message{$msgid}) || $message{$msgid} eq '') { |
if (!exists($message{$msgid}) || $message{$msgid} eq '') { |
if (&Apache::slotrequest::network_error(%message)) { |
if (&Apache::lonnet::error(%message)) { |
return (0,&mt('Message not moved, A network error occurred.')); |
return (0,&mt('Message not moved, A network error occurred.')); |
} else { |
} else { |
return (0,&mt('Message not moved as the message is no longer in the source folder.')); |
return (0,&mt('Message not moved as the message is no longer in the source folder.')); |
Line 224 sub movemsg {
|
Line 226 sub movemsg {
|
|
|
my $result =&Apache::lonnet::put('nohist_email'.$trgsuffix, |
my $result =&Apache::lonnet::put('nohist_email'.$trgsuffix, |
{$msgid => $message{$msgid}}); |
{$msgid => $message{$msgid}}); |
if (&Apache::slotrequest::network_error($result)) { |
if (&Apache::lonnet::error($result)) { |
return (0,&mt('Message not moved, A network error occurred.')); |
return (0,&mt('Message not moved, A network error occurred.')); |
} |
} |
|
|
Line 232 sub movemsg {
|
Line 234 sub movemsg {
|
unless ($trgfolder eq 'trash') { |
unless ($trgfolder eq 'trash') { |
my %status=&Apache::lonnet::get('email_status'.$srcsuffix,[$msgid]); |
my %status=&Apache::lonnet::get('email_status'.$srcsuffix,[$msgid]); |
# a non-existant status is the mark of an unread msg |
# a non-existant status is the mark of an unread msg |
if (&Apache::slotrequest::network_error(%status)) { |
if (&Apache::lonnet::error(%status)) { |
return (0,&mt('Message copied to new folder but status was not, A network error occurred.')); |
return (0,&mt('Message copied to new folder but status was not, A network error occurred.')); |
} |
} |
my $result=&Apache::lonnet::put('email_status'.$trgsuffix, |
my $result=&Apache::lonnet::put('email_status'.$trgsuffix, |
{$msgid => $status{$msgid}}); |
{$msgid => $status{$msgid}}); |
if (&Apache::slotrequest::network_error($result)) { |
if (&Apache::lonnet::error($result)) { |
return (0,&mt('Message copied to new folder but status was not, A network error occurred.')); |
return (0,&mt('Message copied to new folder but status was not, A network error occurred.')); |
} |
} |
} |
} |
Line 247 sub movemsg {
|
Line 249 sub movemsg {
|
&Apache::lonnet::del('nohist_email'.$srcsuffix,[$msgid]); |
&Apache::lonnet::del('nohist_email'.$srcsuffix,[$msgid]); |
my $result_del_stat = |
my $result_del_stat = |
&Apache::lonnet::del('email_status'.$srcsuffix,[$msgid]); |
&Apache::lonnet::del('email_status'.$srcsuffix,[$msgid]); |
if (&Apache::slotrequest::network_error($result_del_msg)) { |
if (&Apache::lonnet::error($result_del_msg)) { |
return (0,&mt('Message copied, but unable to delete the original from the source folder.')); |
return (0,&mt('Message copied, but unable to delete the original from the source folder.')); |
} |
} |
if (&Apache::slotrequest::network_error($result_del_stat)) { |
if (&Apache::lonnet::error($result_del_stat)) { |
return (0,&mt('Message copied, but unable to delete the original status from the source folder.')); |
return (0,&mt('Message copied, but unable to delete the original status from the source folder.')); |
} |
} |
|
|
Line 318 $content{'sendername'}.':'.
|
Line 320 $content{'sendername'}.':'.
|
# Check to see if there were any messages. |
# Check to see if there were any messages. |
if ($result eq '') { |
if ($result eq '') { |
$result = "<h2>".&mt('You have no critical messages.')."</h2>". |
$result = "<h2>".&mt('You have no critical messages.')."</h2>". |
'<a href="/adm/roles">'.&mt('Select a course').'</a><br />'. |
'<a href="/adm/roles">'.&mt('Select a course or group').'</a><br />'. |
'<a href="/adm/email">'.&mt('Communicate').'</a>'; |
'<a href="/adm/email">'.&mt('Communicate').'</a>'; |
} else { |
} else { |
$r->print($header); |
$r->print($header); |
Line 344 sub sortedmessages {
|
Line 346 sub sortedmessages {
|
} |
} |
|
|
foreach my $msgid (@messages) { |
foreach my $msgid (@messages) { |
my $esc_msgid=&Apache::lonnet::escape($msgid); |
my $esc_msgid=&escape($msgid); |
my ($sendtime,$shortsubj,$fromname,$fromdomain,$status,$fromcid)= |
my ($sendtime,$shortsubj,$fromname,$fromdomain,$status,$fromcid)= |
&Apache::lonmsg::unpackmsgid($esc_msgid,$folder,undef, |
&Apache::lonmsg::unpackmsgid($esc_msgid,$folder,undef, |
\%status_cache); |
\%status_cache); |
Line 470 sub disnew {
|
Line 472 sub disnew {
|
&Apache::lonnet::get('email_status',\@msgids); |
&Apache::lonnet::get('email_status',\@msgids); |
my %descriptions; |
my %descriptions; |
foreach (@msgids) { |
foreach (@msgids) { |
my $msgid=&Apache::lonnet::escape($_); |
my $msgid=&escape($_); |
my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)= |
my ($sendtime,$shortsubj,$fromname,$fromdom,$status,$fromcid)= |
&Apache::lonmsg::unpackmsgid($msgid,undef,undef,\%status_cache); |
&Apache::lonmsg::unpackmsgid($msgid,undef,undef,\%status_cache); |
if (defined($sendtime) && $sendtime!~/error/) { |
if (defined($sendtime) && $sendtime!~/error/) { |
Line 569 sub disfolder {
|
Line 571 sub disfolder {
|
function uncheckall() { |
function uncheckall() { |
for (i=0; i<document.forms.disall.elements.length; i++) { |
for (i=0; i<document.forms.disall.elements.length; i++) { |
if |
if |
(document.forms.disall.elements[i].name.indexOf('delmark_')==0) { |
(document.forms.disall.elements[i].name.indexof('delmark_')==0) { |
document.forms.disall.elements[i].checked=false; |
document.forms.disall.elements[i].checked=false; |
} |
} |
} |
} |
Line 653 ENDDISHEADER
|
Line 655 ENDDISHEADER
|
$dis_name = join('<br />',@{$recv_name}); |
$dis_name = join('<br />',@{$recv_name}); |
$dis_domain = join('<br />',@{$recv_domain}); |
$dis_domain = join('<br />',@{$recv_domain}); |
} else { |
} else { |
my $msg_id = &Apache::lonnet::unescape($origID); |
my $msg_id = &unescape($origID); |
my %message = &Apache::lonnet::get('nohist_email'.$suffix, |
my %message = &Apache::lonnet::get('nohist_email'.$suffix, |
[$msg_id]); |
[$msg_id]); |
my %content = &Apache::lonmsg::unpackagemsg($message{$msg_id}); |
my %content = &Apache::lonmsg::unpackagemsg($message{$msg_id}); |
Line 672 ENDDISHEADER
|
Line 674 ENDDISHEADER
|
} elsif ($status eq 'deleted') { |
} elsif ($status eq 'deleted') { |
# purge |
# purge |
my ($result,$msg) = |
my ($result,$msg) = |
&movemsg(&Apache::lonnet::unescape($origID),$folder,'trash'); |
&movemsg(&unescape($origID),$folder,'trash'); |
|
|
} |
} |
} |
} |
Line 716 sub compout {
|
Line 718 sub compout {
|
'Broadcast Message'); |
'Broadcast Message'); |
} elsif ($forwarding) { |
} elsif ($forwarding) { |
&Apache::lonhtmlcommon::add_breadcrumb |
&Apache::lonhtmlcommon::add_breadcrumb |
({href=>"/adm/email?display=".&Apache::lonnet::escape($forwarding), |
({href=>"/adm/email?display=".&escape($forwarding), |
text=>"Display Message"}); |
text=>"Display Message"}); |
&printheader($r,'/adm/email?forward='.&Apache::lonnet::escape($forwarding), |
&printheader($r,'/adm/email?forward='.&escape($forwarding), |
'Forwarding a Message'); |
'Forwarding a Message'); |
} elsif ($replying) { |
} elsif ($replying) { |
&Apache::lonhtmlcommon::add_breadcrumb |
&Apache::lonhtmlcommon::add_breadcrumb |
({href=>"/adm/email?display=".&Apache::lonnet::escape($replying), |
({href=>"/adm/email?display=".&escape($replying), |
text=>"Display Message"}); |
text=>"Display Message"}); |
&printheader($r,'/adm/email?replyto='.&Apache::lonnet::escape($replying), |
&printheader($r,'/adm/email?replyto='.&escape($replying), |
'Replying to a Message'); |
'Replying to a Message'); |
} elsif ($replycrit) { |
} elsif ($replycrit) { |
$r->print('<h3>'.&mt('Replying to a Critical Message').'</h3>'); |
$r->print('<h3>'.&mt('Replying to a Critical Message').'</h3>'); |
Line 774 sub compout {
|
Line 776 sub compout {
|
$dismsg=&mt('Forwarded message from').' '. |
$dismsg=&mt('Forwarded message from').' '. |
$content{'sendername'}.' '.&mt('at').' '.$content{'senderdomain'}; |
$content{'sendername'}.' '.&mt('at').' '.$content{'senderdomain'}; |
if ($content{'baseurl'}) { |
if ($content{'baseurl'}) { |
$disbase='<input type="hidden" name="baseurl" value="'.&Apache::lonnet::escape($content{'baseurl'}).'" />'; |
$disbase='<input type="hidden" name="baseurl" value="'.&escape($content{'baseurl'}).'" />'; |
} |
} |
} |
} |
if ($replying) { |
if ($replying) { |
Line 790 sub compout {
|
Line 792 sub compout {
|
$dismsg=~s/\f/\n/g; |
$dismsg=~s/\f/\n/g; |
$dismsg=~s/\n+/\n\> /g; |
$dismsg=~s/\n+/\n\> /g; |
if ($content{'baseurl'}) { |
if ($content{'baseurl'}) { |
$disbase='<input type="hidden" name="baseurl" value="'.&Apache::lonnet::escape($content{'baseurl'}).'" />'; |
$disbase='<input type="hidden" name="baseurl" value="'.&escape($content{'baseurl'}).'" />'; |
if ($env{'user.adv'}) { |
if ($env{'user.adv'}) { |
$disbase.='<label><input type="checkbox" name="storebasecomment" />'.&mt('Store message for re-use'). |
$disbase.='<label><input type="checkbox" name="storebasecomment" />'.&mt('Store message for re-use'). |
'</label> <a href="/adm/email?showcommentbaseurl='. |
'</label> <a href="/adm/email?showcommentbaseurl='. |
&Apache::lonnet::escape($content{'baseurl'}).'" target="comments">'. |
&escape($content{'baseurl'}).'" target="comments">'. |
&mt('Show re-usable messages').'</a><br />'; |
&mt('Show re-usable messages').'</a><br />'; |
} |
} |
} |
} |
Line 881 ENDUPLOAD
|
Line 883 ENDUPLOAD
|
my $studentsel = &discourse(); |
my $studentsel = &discourse(); |
$r->print($studentsel); |
$r->print($studentsel); |
} |
} |
|
if ($env{'form.displayedcrit'}) { |
|
$r->print('<input type="hidden" name="displayedcrit" value="true" />'); |
|
} |
$r->print('</form>'. |
$r->print('</form>'. |
&Apache::lonfeedback::generate_preview_button('compemail','message'). |
&Apache::lonfeedback::generate_preview_button('compemail','message'). |
&Apache::lonhtmlcommon::htmlareaselectactive('message')); |
&Apache::lonhtmlcommon::htmlareaselectactive('message')); |
Line 940 sub disfacetoface {
|
Line 945 sub disfacetoface {
|
$result .='<h3>'.&mt('Broadcast Message').'</h3>'; |
$result .='<h3>'.&mt('Broadcast Message').'</h3>'; |
if ($content{'subject'}=~/^Broadcast\./) { |
if ($content{'subject'}=~/^Broadcast\./) { |
if (defined($content{'coursemsgid'})) { |
if (defined($content{'coursemsgid'})) { |
my $crsmsgid = &Apache::lonnet::escape($content{'coursemsgid'}); |
my $crsmsgid = &escape($content{'coursemsgid'}); |
my $broadcast_message = &general_message($crsmsgid); |
my $broadcast_message = &general_message($crsmsgid); |
$content{'message'} = '<b>'.&mt('Subject').': '.$content{'message'}.'</b><br />'.$broadcast_message; |
$content{'message'} = '<b>'.&mt('Subject').': '.$content{'message'}.'</b><br />'.$broadcast_message; |
} else { |
} else { |
Line 953 sub disfacetoface {
|
Line 958 sub disfacetoface {
|
} else { |
} else { |
$result.='<h3>'.&mt('Critical Message').'</h3>'; |
$result.='<h3>'.&mt('Critical Message').'</h3>'; |
if (defined($content{'coursemsgid'})) { |
if (defined($content{'coursemsgid'})) { |
my $crsmsgid=&Apache::lonnet::escape($content{'coursemsgid'}); |
my $crsmsgid=&escape($content{'coursemsgid'}); |
my $critical_message = &general_message($crsmsgid); |
my $critical_message = &general_message($crsmsgid); |
$content{'message'} = '<b>'.&mt('Subject').': '.$content{'message'}.'</b><br />'.$critical_message; |
$content{'message'} = '<b>'.&mt('Subject').': '.$content{'message'}.'</b><br />'.$critical_message; |
} else { |
} else { |
Line 974 $content{'sendername'}.':'.
|
Line 979 $content{'sendername'}.':'.
|
} |
} |
# Check to see if there were any messages. |
# Check to see if there were any messages. |
if ($result eq '') { |
if ($result eq '') { |
|
my $lctype = lc(&Apache::loncommon::course_type()); |
if ($target ne 'tex') { |
if ($target ne 'tex') { |
$r->print("<p><b>".&mt("No notes, face-to-face discussion records, critical messages, or broadcast messages in this course.")."</b></p>"); |
$r->print("<p><b>".&mt('No notes, face-to-face discussion records, critical messages, or broadcast messages in this [_1].',$lctype)."</b></p>"); |
} else { |
} else { |
$r->print('\textbf{'.&mt("No notes, face-to-face discussion records, critical messages or broadcast messages in this course.").'}\\\\'); |
$r->print('\textbf{'.&mt('No notes, face-to-face discussion records, critical messages or broadcast messages in this [_1].',$lctype).'}\\\\'); |
} |
} |
} else { |
} else { |
$r->print($result); |
$r->print($result); |
Line 1006 sub facetoface {
|
Line 1012 sub facetoface {
|
$r->print('Not allowed'); |
$r->print('Not allowed'); |
return; |
return; |
} |
} |
|
my $crstype = &Apache::loncommon::course_type(); |
|
my $leaders = ($crstype eq 'Group') ? 'coordinators and leaders' |
|
: 'faculty and staff'; |
&printheader($r, |
&printheader($r, |
'/adm/email?recordftf=query', |
'/adm/email?recordftf=query', |
"User Notes, Face-to-Face, Critical Messages, Broadcast Messages"); |
"User Notes, Face-to-Face, Critical Messages, Broadcast Messages"); |
Line 1023 sub facetoface {
|
Line 1032 sub facetoface {
|
('stdselect','recuname','recdomain'); |
('stdselect','recuname','recdomain'); |
my %lt=&Apache::lonlocal::texthash('user' => 'Username', |
my %lt=&Apache::lonlocal::texthash('user' => 'Username', |
'dom' => 'Domain', |
'dom' => 'Domain', |
'head' => 'User Notes, Records of Face-To-Face Discussions, Critical Messages, and Broadcast Messages in Course', |
'head' => "User Notes, Records of Face-To-Face Discussions, Critical Messages, and Broadcast Messages in $crstype", |
'subm' => 'Retrieve discussion and message records', |
'subm' => 'Retrieve discussion and message records', |
'newr' => 'New Record (record is visible to course faculty and staff)', |
'newr' => 'New Record (record is visible to '.lc($crstype).' '.$leaders.')', |
'post' => 'Post this Record'); |
'post' => 'Post this Record'); |
$r->print(<<"ENDTREC"); |
$r->print(<<"ENDTREC"); |
<h3>$lt{'head'}</h3> |
<h3>$lt{'head'}</h3> |
Line 1046 ENDTREC
|
Line 1055 ENDTREC
|
($env{'form.recdomain'}) && ($env{'form.recuname'})) { |
($env{'form.recdomain'}) && ($env{'form.recuname'})) { |
chomp($env{'form.newrecord'}); |
chomp($env{'form.newrecord'}); |
if ($env{'form.newrecord'}) { |
if ($env{'form.newrecord'}) { |
my $recordtxt = $env{'form.newrecord'}; |
&Apache::lonmsg::store_instructor_comment($env{'form.newrecord'}, |
&Apache::lonmsg::user_normal_msg_raw( |
$env{'form.recuname'}, |
$env{'course.'.$env{'request.course.id'}.'.num'}, |
$env{'form.recdomain'}); |
$env{'course.'.$env{'request.course.id'}.'.domain'}, |
|
&mt('Record'). |
|
' ['.$env{'form.recuname'}.':'.$env{'form.recdomain'}.']', |
|
$recordtxt); |
|
} |
} |
$r->print('<h3>'.&Apache::loncommon::plainname($env{'form.recuname'}, |
$r->print('<h3>'.&Apache::loncommon::plainname($env{'form.recuname'}, |
$env{'form.recdomain'}).'</h3>'); |
$env{'form.recdomain'}).'</h3>'); |
Line 1084 sub examblock {
|
Line 1089 sub examblock {
|
$r->print('Not allowed'); |
$r->print('Not allowed'); |
return; |
return; |
} |
} |
|
my $usertype = (&Apache::loncommon::course_type() eq 'Group') ? 'members' |
|
: 'students'; |
my %lt=&Apache::lonlocal::texthash( |
my %lt=&Apache::lonlocal::texthash( |
'comb' => 'Communication Blocking', |
'comb' => 'Communication Blocking', |
'cbds' => 'Communication blocking during scheduled exams', |
'cbds' => 'Communication blocking during scheduled exams', |
'desc' => 'You can use communication blocking to prevent students enrolled in this course from displaying LON-CAPA messages sent by other students during an online exam. As blocking of communication could potentially interrupt legitimate communication between students who are also both enrolled in a different LON-CAPA course, please be careful that you select the correct start and end times for your scheduled exam when setting or modifying these parameters.', |
'desc' => "You can use communication blocking to prevent $usertype enrolled in this course from displaying LON-CAPA messages sent by other $usertype during an online exam. As blocking of communication could potentially interrupt legitimate communication between $usertype who are also both enrolled in a different LON-CAPA course, please be careful that you select the correct start and end times for your scheduled exam when setting or modifying these parameters.", |
'mecb' => 'Modify existing communication blocking periods', |
'mecb' => 'Modify existing communication blocking periods', |
'ncbc' => 'No communication blocks currently stored' |
'ncbc' => 'No communication blocks currently stored' |
); |
); |
Line 1419 sub displaymessage {
|
Line 1426 sub displaymessage {
|
my $startblock = 0; |
my $startblock = 0; |
my $endblock = 0; |
my $endblock = 0; |
my $numblocked = 0; |
my $numblocked = 0; |
|
my $crstype = &Apache::loncommon::course_type(); |
|
|
# info to generate "next" and "previous" buttons and check if message is blocked |
# info to generate "next" and "previous" buttons and check if message is blocked |
&blockcheck(\%setters,\$startblock,\$endblock); |
&blockcheck(\%setters,\$startblock,\$endblock); |
my @messages=&sortedmessages(\%blocked,$startblock,$endblock,\$numblocked,$folder); |
my @messages=&sortedmessages(\%blocked,$startblock,$endblock,\$numblocked,$folder); |
Line 1434 sub displaymessage {
|
Line 1443 sub displaymessage {
|
|
|
my $counter=0; |
my $counter=0; |
$r->print('<pre>'); |
$r->print('<pre>'); |
my $escmsgid=&Apache::lonnet::escape($msgid); |
my $escmsgid=&escape($msgid); |
foreach (@messages) { |
foreach (@messages) { |
if ($_->[5] eq $escmsgid){ |
if ($_->[5] eq $escmsgid){ |
last; |
last; |
Line 1444 sub displaymessage {
|
Line 1453 sub displaymessage {
|
$r->print('</pre>'); |
$r->print('</pre>'); |
my $number_of_messages = scalar(@messages); #subtract 1 for last index |
my $number_of_messages = scalar(@messages); #subtract 1 for last index |
# start output |
# start output |
&printheader($r,'/adm/email?display='.&Apache::lonnet::escape($msgid),'Display a Message','',$content{'baseurl'}); |
&printheader($r,'/adm/email?display='.&escape($msgid),'Display a Message','',$content{'baseurl'}); |
my %courseinfo=&Apache::lonnet::coursedescription($content{'courseid'}); |
my %courseinfo=&Apache::lonnet::coursedescription($content{'courseid'}); |
# Functions |
# Functions |
$r->print('<table border="2" width="100%"><tr bgcolor="#FFFFAA"><td>'.&mt('Functions').':</td>'. |
$r->print('<table border="2" width="100%"><tr bgcolor="#FFFFAA"><td>'.&mt('Functions').':</td>'. |
'<td><a href="/adm/email?replyto='.&Apache::lonnet::escape($msgid).$sqs. |
'<td><a href="/adm/email?replyto='.&escape($msgid).$sqs. |
'"><b>'.&mt('Reply').'</b></a></td>'. |
'"><b>'.&mt('Reply').'</b></a></td>'. |
'<td><a href="/adm/email?forward='.&Apache::lonnet::escape($msgid).$sqs. |
'<td><a href="/adm/email?forward='.&escape($msgid).$sqs. |
'"><b>'.&mt('Forward').'</b></a></td>'. |
'"><b>'.&mt('Forward').'</b></a></td>'. |
'<td><a href="/adm/email?markunread='.&Apache::lonnet::escape($msgid).$sqs. |
'<td><a href="/adm/email?markunread='.&escape($msgid).$sqs. |
'"><b>'.&mt('Mark Unread').'</b></a></td>'. |
'"><b>'.&mt('Mark Unread').'</b></a></td>'. |
'<td><a href="/adm/email?markdel='.&Apache::lonnet::escape($msgid).$sqs. |
'<td><a href="/adm/email?markdel='.&escape($msgid).$sqs. |
'"><b>'.&mt('Delete').'</b></a></td>'. |
'"><b>'.&mt('Delete').'</b></a></td>'. |
'<td><a href="/adm/email?'.$sqs. |
'<td><a href="/adm/email?'.$sqs. |
($env{'form.dismode'} eq 'new'?'&folder=new':''). |
($env{'form.dismode'} eq 'new'?'&folder=new':''). |
Line 1500 sub displaymessage {
|
Line 1509 sub displaymessage {
|
$content{'sendername'}.' at '. |
$content{'sendername'}.' at '. |
$content{'senderdomain'}.') ':'<br /><b>'.&mt('To').':</b> '. |
$content{'senderdomain'}.') ':'<br /><b>'.&mt('To').':</b> '. |
$tolist). |
$tolist). |
($content{'courseid'}?'<br /><b>'.&mt('Course').':</b> '.$courseinfo{'description'}. |
($content{'courseid'}?'<br /><b>'.&mt($crstype).':</b> '.$courseinfo{'description'}. |
($content{'coursesec'}?' ('.&mt('Group/Section').': '.$content{'coursesec'}.')':''):''). |
($content{'coursesec'}?' ('.&mt('Section').': '.$content{'coursesec'}.')':''):''). |
'<br /><b>'.&mt('Time').':</b> '.$content{'time'}. |
'<br /><b>'.&mt('Time').':</b> '.$content{'time'}. |
($content{'baseurl'}?'<br /><b>'.&mt('Refers to').':</b> <a href="'.$content{'baseurl'}.'">'. |
($content{'baseurl'}?'<br /><b>'.&mt('Refers to').':</b> <a href="'.$content{'baseurl'}.'">'. |
$content{'baseurl'}.' ('.&Apache::lonnet::gettitle($content{'baseurl'}).')</a>':''). |
$content{'baseurl'}.' ('.&Apache::lonnet::gettitle($content{'baseurl'}).')</a>':''). |
Line 1583 sub storecomment {
|
Line 1592 sub storecomment {
|
$cleanmsgtxt.=$_."\n"; |
$cleanmsgtxt.=$_."\n"; |
} |
} |
} |
} |
my $key=&Apache::lonnet::escape($env{'form.baseurl'}).'___'.time; |
my $key=&escape($env{'form.baseurl'}).'___'.time; |
&Apache::lonnet::put('nohist_stored_comments',{ $key => $cleanmsgtxt }); |
&Apache::lonnet::put('nohist_stored_comments',{ $key => $cleanmsgtxt }); |
} |
} |
|
|
sub storedcommentlisting { |
sub storedcommentlisting { |
my ($r)=@_; |
my ($r)=@_; |
my %msgs=&Apache::lonnet::dump('nohist_stored_comments',undef,undef, |
my %msgs=&Apache::lonnet::dump('nohist_stored_comments',undef,undef, |
'^'.&Apache::lonnet::escape(&Apache::lonnet::escape($env{'form.showcommentbaseurl'}))); |
'^'.&escape(&escape($env{'form.showcommentbaseurl'}))); |
$r->print(&Apache::loncommon::start_page('Stored Comment Listing',undef, |
$r->print(&Apache::loncommon::start_page('Stored Comment Listing',undef, |
{'onlybody' => 1})); |
{'onlybody' => 1})); |
if ((keys %msgs)[0]=~/^error\:/) { |
if ((keys %msgs)[0]=~/^error\:/) { |
Line 1635 sub sendoffmail {
|
Line 1644 sub sendoffmail {
|
&statuschange($msgid,'replied',$folder); |
&statuschange($msgid,'replied',$folder); |
} |
} |
|
|
my $to = $env{'form.selectedusers.forminput'}; |
my @to = |
|
&Apache::loncommon::get_env_multiple('form.selectedusers.forminput'); |
my $mode = $env{'form.sendmode'}; |
my $mode = $env{'form.sendmode'}; |
|
|
my %toaddr; |
my %toaddr; |
if ($to) { |
if (@to) { |
foreach my $dest (@$to) { |
foreach my $dest (@to) { |
my ($user,$domain) = split(/:/, $dest); |
my ($user,$domain) = split(/:/, $dest); |
if (($user ne '') && ($domain ne '')) { |
if (($user ne '') && ($domain ne '')) { |
my $address = $user.":".$domain; # How the code below expects it. |
my $address = $user.":".$domain; # How the code below expects it. |
Line 1742 sub sendoffmail {
|
Line 1752 sub sendoffmail {
|
my ($specialmsgid,$specialresult); |
my ($specialmsgid,$specialresult); |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cnum = $env{'course.'.$env{'request.course.id'}.'.num'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $cdom = $env{'course.'.$env{'request.course.id'}.'.domain'}; |
my $course_str = &Apache::lonnet::escape('['.$cnum.':'.$cdom.']'); |
my $course_str = &escape('['.$cnum.':'.$cdom.']'); |
|
|
if ($numspecial) { |
if ($numspecial) { |
$specialresult = &Apache::lonmsg::user_normal_msg_raw($cnum,$cdom,$subj_prefix. |
$specialresult = &Apache::lonmsg::user_normal_msg_raw($cnum,$cdom,$subj_prefix. |
' '.$course_str,$savemsg,undef,undef,undef, |
' '.$course_str,$savemsg,undef,undef,undef, |
undef,undef,\$specialmsgid); |
undef,undef,\$specialmsgid); |
$specialmsgid = &Apache::lonnet::unescape($specialmsgid); |
$specialmsgid = &unescape($specialmsgid); |
} |
} |
if ($specialresult eq 'ok') { |
if ($specialresult eq 'ok') { |
my $record_sent; |
my $record_sent; |
my @recusers; |
my @recusers; |
my @recudoms; |
my @recudoms; |
my ($stamp,$crssubj,$msgname,$msgdom,$msgcount,$context,$pid) = |
my ($stamp,$crssubj,$msgname,$msgdom,$msgcount,$context,$pid) = |
split(/\:/,&Apache::lonnet::unescape($specialmsgid)); |
split(/\:/,&unescape($specialmsgid)); |
|
|
foreach my $recipient (sort(keys(%toaddr))) { |
foreach my $recipient (sort(keys(%toaddr))) { |
if ($specialmsg_status{$recipient} eq 'ok') { |
if ($specialmsg_status{$recipient} eq 'ok') { |
Line 1845 sub handler {
|
Line 1855 sub handler {
|
unless ($folder) { |
unless ($folder) { |
$folder=''; |
$folder=''; |
} else { |
} else { |
$sqs.='&folder='.&Apache::lonnet::escape($folder); |
$sqs.='&folder='.&escape($folder); |
} |
} |
# ------------------------------------------------------------ Get Display Mode |
# ------------------------------------------------------------ Get Display Mode |
|
|
Line 1853 sub handler {
|
Line 1863 sub handler {
|
unless ($dismode) { |
unless ($dismode) { |
$dismode=''; |
$dismode=''; |
} else { |
} else { |
$sqs.='&dismode='.&Apache::lonnet::escape($dismode); |
$sqs.='&dismode='.&escape($dismode); |
} |
} |
|
|
# --------------------------------------------------------------------- Display |
# --------------------------------------------------------------------- Display |
Line 1889 sub handler {
|
Line 1899 sub handler {
|
&compout($r,'',$env{'form.replyto'},undef,undef,$folder,$dismode); |
&compout($r,'',$env{'form.replyto'},undef,undef,$folder,$dismode); |
} elsif ($env{'form.confirm'}) { |
} elsif ($env{'form.confirm'}) { |
&printheader($r,'','Confirmed Receipt'); |
&printheader($r,'','Confirmed Receipt'); |
|
my $replying = 0; |
foreach (keys %env) { |
foreach (keys %env) { |
if ($_=~/^form\.rec\_(.*)$/) { |
if ($_=~/^form\.rec\_(.*)$/) { |
$r->print('<b>'.&mt('Confirming Receipt').':</b> '. |
$r->print('<b>'.&mt('Confirming Receipt').':</b> '. |
Line 1899 sub handler {
|
Line 1910 sub handler {
|
$r->print('<b>'.&mt('Confirming Receipt').':</b> '. |
$r->print('<b>'.&mt('Confirming Receipt').':</b> '. |
&Apache::lonmsg::user_crit_received($msgid).'<br>'); |
&Apache::lonmsg::user_crit_received($msgid).'<br>'); |
&compout($r,'','','',$msgid); |
&compout($r,'','','',$msgid); |
|
$replying = 1; |
} |
} |
} |
} |
&discrit($r); |
if (!$replying) { |
|
&discrit($r); |
|
} |
} elsif ($env{'form.critical'}) { |
} elsif ($env{'form.critical'}) { |
&printheader($r,'','Displaying Critical Messages'); |
&printheader($r,'','Displaying Critical Messages'); |
&discrit($r); |
&discrit($r); |
Line 1923 sub handler {
|
Line 1937 sub handler {
|
foreach my $key (keys(%env)) { |
foreach my $key (keys(%env)) { |
if ($key=~/^form\.delmark_(.*)$/) { |
if ($key=~/^form\.delmark_(.*)$/) { |
my ($result,$msg) = |
my ($result,$msg) = |
&movemsg(&Apache::lonnet::unescape($1),$folder, |
&movemsg(&unescape($1),$folder, |
$env{'form.movetofolder'}); |
$env{'form.movetofolder'}); |
if ($result) { |
if ($result) { |
$total++; |
$total++; |
Line 1950 sub handler {
|
Line 1964 sub handler {
|
foreach my $key (keys(%env)) { |
foreach my $key (keys(%env)) { |
if ($key=~/^form\.delmark_(.*)$/) { |
if ($key=~/^form\.delmark_(.*)$/) { |
my ($result,$msg) = |
my ($result,$msg) = |
&statuschange(&Apache::lonnet::unescape($1),'deleted', |
&statuschange(&unescape($1),'deleted', |
$folder); |
$folder); |
if ($result) { |
if ($result) { |
$total++; |
$total++; |
Line 1995 sub handler {
|
Line 2009 sub handler {
|
$env{'form.subject'}, |
$env{'form.subject'}, |
$env{'form.message'},'/adm/communicate','public'); |
$env{'form.message'},'/adm/communicate','public'); |
} |
} |
&disall($r,($folder?$folder:$dismode)); |
if (!$env{'form.displayedcrit'}) { |
|
&disall($r,($folder?$folder:$dismode)); |
|
} |
} elsif ($env{'form.newfolder'}) { |
} elsif ($env{'form.newfolder'}) { |
&printheader($r,'','New Folder'); |
&printheader($r,'','New Folder'); |
&makefolder($env{'form.newfolder'}); |
&makefolder($env{'form.newfolder'}); |