--- loncom/interface/loncommunicate.pm 2004/03/01 02:21:57 1.20 +++ loncom/interface/loncommunicate.pm 2006/04/08 06:59:34 1.31 @@ -1,7 +1,7 @@ # The LearningOnline Network # Communicate # -# $Id: loncommunicate.pm,v 1.20 2004/03/01 02:21:57 www Exp $ +# $Id: loncommunicate.pm,v 1.31 2006/04/08 06:59:34 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -31,125 +31,85 @@ package Apache::loncommunicate; use strict; use Apache::Constants qw(:common); -use Apache::lonmsg(); +use Apache::lonmsgdisplay(); use Apache::loncommon; use Apache::lonlocal; +use Apache::lonnet; -sub handler { - my $r = shift; - &Apache::loncommon::content_type($r,'text/html'); - $r->send_http_header; - return OK if $r->header_only; -# -# Start document -# - $r->print(< - -The LearningOnline Network with CAPA - -END - my %lt=&Apache::lonlocal::texthash( -'vam' => 'View All Messages', +sub menu { + my $r=shift; + my %lt=&Apache::lonlocal::texthash( +'mnf' => 'Make New Folder', 'vcm' => 'View Critical Messages', 'smu' => 'Send Message to User(s)', 'bmc' => 'Broadcast Message to Course', 'dmu' => 'Distribute Messages from Uploaded File to Course', 'unr' => 'User Notes, Records of Face-to-Face Discussions, and Critical Messages', -'nm' => 'New Messages', -'su' => 'Subject', -'da' => 'Date', -'us' => 'Username', -'op' => 'Open', -'do' => 'Domain' + +'cbs' => 'Configure blocking of student communication during exams' + ); my %help=(); foreach ('Course_Face_To_Face_Records,Course_Critical_Message', 'Course_Broadcast_Message') { $help{$_}=&Apache::loncommon::help_open_topic($_); } - -# ----------------------------------------------------------------- Breadcrumbs - &Apache::lonhtmlcommon::clear_breadcrumbs(); - &Apache::lonhtmlcommon::add_breadcrumb - ({href=>"/adm/communicate", - text=>"Communication/Messages", - faq=>12,bug=>'Communication Tools',}); - -# ---------------------------------------------------------------------- Header - &Apache::lonmsg::header($r); - # ------------------------------------------------------------------------ Menu $r->print(< - - $lt{'vam'} - - - $lt{'vcm'} - - +
+ + +
+ $lt{'smu'} END - if (($ENV{'request.course.id'}) && - (&Apache::lonnet::allowed('srm',$ENV{'request.course.id'}))) { + if (($env{'request.course.id'}) && + ( + &Apache::lonnet::allowed('srm',$env{'request.course.id'}) || + &Apache::lonnet::allowed('srm',$env{'request.course.id'}.'/'.$env{'request.course.sec'}) + )) { $r->print(< $lt{'bmc'}$help{'Course_Broadcast_Message'} - - + + $lt{'dmu'} $lt{'unr'}$help{'Course_Face_To_Face_Records,Course_Critical_Message'} + + + $lt{'cbs'} - END } $r->print(''); - my @msgids = sort split(/\&/,&Apache::lonnet::reply - ('keys:'.$ENV{'user.domain'}.':'. - $ENV{'user.name'}.':nohist_email', - $ENV{'user.home'})); - my @newmsgs; - foreach (@msgids) { - my ($sendtime,$shortsubj,$fromname,$fromdom,$status)= - &Apache::lonmsg::unpackmsgid($_); - if (defined($sendtime) && $sendtime!~/error/) { - $sendtime = &Apache::lonlocal::locallocaltime($sendtime); - if ($status eq 'new') { - push @newmsgs, { - msgid => $_, - sendtime => $sendtime, - shortsub => &Apache::lonnet::unescape($shortsubj), - from => $fromname, - fromdom => $fromdom - } - } - } - } - if ($#newmsgs >= 0) { - $r->print(<$lt{'nm'} - - -TABLEHEAD - foreach my $msg (@newmsgs) { - $r->print(<<"ENDLINK"); - - -ENDLINK - foreach ('sendtime','from','fromdom','shortsub') { - $r->print(""); - } - $r->print(""); - } - $r->print('
 $lt{'da'}$lt{'us'}$lt{'do'}$lt{'su'}
$lt{'op'}$msg->{$_}
'); - } else { - $r->print("

".&mt('You have no unread messages')."

"); - } +} + +sub handler { + my $r = shift; + &Apache::loncommon::content_type($r,'text/html'); + $r->send_http_header; + return OK if $r->header_only; +# +# Start document +# + +# ----------------------------------------------------------------- Breadcrumbs + &Apache::lonhtmlcommon::clear_breadcrumbs(); + &Apache::lonhtmlcommon::add_breadcrumb + ({href=>"/adm/communicate", + text=>"Communication/Messages", + faq=>12,bug=>'Communication Tools',}); + +# ---------------------------------------------------------------------- Header + &Apache::lonmsgdisplay::header($r); + &menu($r); + &Apache::lonmsgdisplay::disall($r,'new'); + $r->print(&Apache::loncommon::end_page()); return OK; }