--- loncom/interface/loncommunicate.pm 2004/11/09 16:29:32 1.24 +++ loncom/interface/loncommunicate.pm 2006/11/29 07:53:55 1.35 @@ -1,7 +1,7 @@ # The LearningOnline Network # Communicate # -# $Id: loncommunicate.pm,v 1.24 2004/11/09 16:29:32 www Exp $ +# $Id: loncommunicate.pm,v 1.35 2006/11/29 07:53:55 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -31,22 +31,32 @@ 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 menu { my $r=shift; + my $crstype = 'Course'; + my $usertype = 'Student'; + if (defined($env{'course.'.$env{'request.course.id'}.'.type'})) { + $crstype = $env{'course.'.$env{'request.course.id'}.'.type'}; + if ($crstype eq 'Group') { + $usertype = 'Member'; + } + } 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', +'bmc' => "Broadcast Message to $crstype", +'dmu' => "Distribute Messages from Uploaded File to $crstype", 'unr' => 'User Notes, Records of Face-to-Face Discussions, and Critical Messages', -'cbs' => 'Configure blocking of student communication during exams' +'cbs' => "Configure Blocking of $usertype Communication during Exams", +'blog' => 'Add or Edit Blog Entries' ); my %help=(); @@ -54,36 +64,58 @@ sub menu { 'Course_Broadcast_Message') { $help{$_}=&Apache::loncommon::help_open_topic($_); } - my $folderlist=&Apache::lonmsg::folderlist(); # ------------------------------------------------------------------------ Menu - $r->print(< + my ($can_srm,$can_dcm); + if ($env{'request.course.id'}) { + if ((&Apache::lonnet::allowed('srm',$env{'request.course.id'})) || + (&Apache::lonnet::allowed('srm',$env{'request.course.id'}.'/'. + $env{'request.course.sec'}))) { + $can_srm = 1; + } + if ((&Apache::lonnet::allowed('dcm',$env{'request.course.id'})) || + (&Apache::lonnet::allowed('dcm',$env{'request.course.id'}.'/'. + $env{'request.course.sec'}))) { + $can_dcm = 1; + } + } + $r->print(< +
-
- - + + END - if (($ENV{'request.course.id'}) && - (&Apache::lonnet::allowed('srm',$ENV{'request.course.id'}))) { + if ($can_srm || !$can_dcm) { + $r->print(''); + } + if ($can_srm) { $r->print(< - + - + END } + if ($can_dcm) { + $r->print(' +'); + } + if ($can_srm || $can_dcm) { + $r->print(''); + } $r->print('
+ $lt{'smu'}
+ $lt{'blog'} +
$lt{'bmc'}$help{'Course_Broadcast_Message'} -
+ $lt{'dmu'}
$lt{'unr'}$help{'Course_Face_To_Face_Records,Course_Critical_Message'} -
- $lt{'cbs'} -
+ '.$lt{'cbs'}.' +
'); } @@ -95,12 +127,6 @@ sub handler { # # Start document # - $r->print(< - -The LearningOnline Network with CAPA - -END # ----------------------------------------------------------------- Breadcrumbs &Apache::lonhtmlcommon::clear_breadcrumbs(); @@ -110,9 +136,10 @@ END faq=>12,bug=>'Communication Tools',}); # ---------------------------------------------------------------------- Header - &Apache::lonmsg::header($r); + &Apache::lonmsgdisplay::header($r); &menu($r); - &Apache::lonmsg::disnew($r); + &Apache::lonmsgdisplay::disall($r,'new'); + $r->print(&Apache::loncommon::end_page()); return OK; }