--- loncom/interface/loncommunicate.pm 2001/12/19 17:17:46 1.7 +++ loncom/interface/loncommunicate.pm 2002/12/27 14:59:42 1.13 @@ -1,7 +1,7 @@ # The LearningOnline Network # Communicate # -# $Id: loncommunicate.pm,v 1.7 2001/12/19 17:17:46 albertel Exp $ +# $Id: loncommunicate.pm,v 1.13 2002/12/27 14:59:42 www Exp $ # # Copyright Michigan State University Board of Trustees # @@ -41,6 +41,7 @@ package Apache::loncommunicate; use strict; use Apache::Constants qw(:common); use Apache::lonmsg(); +use Apache::loncommon; sub handler { my $r = shift; @@ -50,50 +51,82 @@ sub handler { # # Start document # - $r->print(<print(< The LearningOnline Network with CAPA - - -

Communicate

-ENDDOCUMENT - my $st='
'; - my $en='
'; - $r->print('

'. - $st.'All Messages'.$en.'

'. - $st.'Critical Messages'.$en.'

'. - $st.'Send message to user(s)'.$en - ); +END + $r->print(&Apache::loncommon::bodytag("Communication and Messages")); + $r->print(< + + View All Messages + + + View Critical Messages + + + Send message to user(s) + +END if (($ENV{'request.course.id'}) && (&Apache::lonnet::allowed('srm',$ENV{'request.course.id'}))) { - $r->print( - '

'.$st. - 'Broadcast message to course'.$en. - '

'.$st. - 'Upload messages to course'.$en); + $r->print(< + Broadcast message to course + + + Distribute messages from uploaded file to course + + + User records of face-to-face discusssions and messages + + +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 = localtime($sendtime); + if ($status eq 'new') { + push @newmsgs, { + msgid => $_, + sendtime => $sendtime, + shortsub => &Apache::lonnet::unescape($shortsubj), + from => $fromname, + fromdom => $fromdom + } + } + } } - $r->print(<= 0) { + $r->print(<New Messages -ENDTABLE - map { - my ($sendtime,$shortsubj,$fromname,$fromdomain,$status)= - &Apache::lonmsg::unpackmsgid($_); - if ($status eq 'new') { - $r->print( - ''); +TABLEHEAD + foreach my $msg (@newmsgs) { + $r->print(<<"ENDLINK"); + + +ENDLINK + foreach ('sendtime','from','fromdom','shortsub') { + $r->print(""); + } + $r->print(""); } - } sort split(/\&/,&Apache::lonnet::reply('keys:'. - $ENV{'user.domain'}.':'. - $ENV{'user.name'}.':nohist_email', - $ENV{'user.home'})); - $r->print('
  DateUsernameDomainSubject
Open'.localtime($sendtime).''. - $fromname.''.$fromdomain.''. - &Apache::lonnet::unescape($shortsubj).'
Open$msg->{$_}
'); + $r->print(''); + } else { + $r->print("

You have no unread messages

"); + } return OK; }