version 1.32, 2004/09/02 13:15:07
|
version 1.46, 2006/03/15 21:55:43
|
Line 33 use Apache::Constants qw(:common);
|
Line 33 use Apache::Constants qw(:common);
|
use Apache::loncommon; |
use Apache::loncommon; |
use Apache::lonhtmlcommon(); |
use Apache::lonhtmlcommon(); |
use Apache::lonlocal; |
use Apache::lonlocal; |
|
use Apache::lonnavmaps(); |
|
use Apache::lonrss(); |
|
use Apache::lonnet; |
use HTML::Entities(); |
use HTML::Entities(); |
|
|
my %todayhash; |
my %todayhash; |
Line 48 sub editfield {
|
Line 51 sub editfield {
|
'enddate', |
'enddate', |
$end); |
$end); |
my $help=&Apache::loncommon::help_open_menu('','Calendar Add Announcement','Calendar_Add_Announcement','',274,'Communication Tools'); |
my $help=&Apache::loncommon::help_open_menu('','Calendar Add Announcement','Calendar_Add_Announcement','',274,'Communication Tools'); |
|
my %lt=&Apache::lonlocal::texthash('post' => 'Post Announcement', |
|
'start' => 'Starting date', |
|
'end' => 'Ending date', |
|
'incrss' => 'Include in course RSS newsfeed'); |
|
|
$r->print(<<ENDFORM); |
$r->print(<<ENDFORM); |
$help |
$help |
<form name="anno" method="post"> |
<form name="anno" method="post"> |
<input type="hidden" value='' name="action" > |
<input type="hidden" value='' name="action" /> |
<table><tr><td>Starting date:</td><td>$startdateform</td></tr> |
<table><tr><td>$lt{'start'}:</td><td>$startdateform</td></tr> |
<tr><td>Ending date:</td><td>$enddateform</td></tr></table> |
<tr><td>$lt{'end'}:</td><td>$enddateform</td></tr></table> |
<textarea name="msg" rows="4" cols="60">$text</textarea> |
<textarea name="msg" rows="4" cols="60">$text</textarea> |
<input type="button" onClick="trysubmit()" value="Post Announcement"><hr /> |
<br /> |
|
<label><input type="checkbox" name="rsspost" /> $lt{'incrss'}</label> |
|
<br /><input type="button" onClick="trysubmit()" value="$lt{'post'}" /><hr /> |
ENDFORM |
ENDFORM |
} |
} |
|
|
sub readcalendar { |
sub readcalendar { |
my $courseid=shift; |
my $courseid=shift; |
my $coursenum=$ENV{'course.'.$courseid.'.num'}; |
my $coursenum=$env{'course.'.$courseid.'.num'}; |
my $coursedom=$ENV{'course.'.$courseid.'.domain'}; |
my $coursedom=$env{'course.'.$courseid.'.domain'}; |
my %thiscal=&Apache::lonnet::dump('calendar',$coursedom,$coursenum); |
my %thiscal=&Apache::lonnet::dump('calendar',$coursedom,$coursenum); |
my %returnhash=(); |
my %returnhash=(); |
foreach (keys %thiscal) { |
foreach my $item (keys(%thiscal)) { |
unless (($_=~/^error\:/) || ($thiscal{$_}=~/^error\:/)) { |
unless (($item=~/^error\:/) || ($thiscal{$item}=~/^error\:/)) { |
$returnhash{$courseid.'@'.$_}=$thiscal{$_}; |
$returnhash{$courseid.'@'.$item}=$thiscal{$item}; |
} |
} |
} |
} |
if ($courseid eq $ENV{'request.course.id'}) { |
|
|
if ($courseid eq $env{'request.course.id'}) { |
|
my $can_see_hidden = $env{'request.role.adv'}; |
|
my $navmap = Apache::lonnavmaps::navmap->new(); |
my %resourcedata= |
my %resourcedata= |
&Apache::lonnet::dump('resourcedata',$coursedom,$coursenum); |
&Apache::lonnet::dump('resourcedata',$coursedom,$coursenum); |
foreach my $thiskey (sort keys %resourcedata) { |
foreach my $thiskey (sort keys %resourcedata) { |
Line 81 sub readcalendar {
|
Line 94 sub readcalendar {
|
if ($middle=~/^\[(.*)\]\./) { |
if ($middle=~/^\[(.*)\]\./) { |
my $sec=$1; |
my $sec=$1; |
# if we have a section don't show ones that aren't ours |
# if we have a section don't show ones that aren't ours |
if ($ENV{'request.course.sec'} && |
if ($env{'request.course.sec'} && |
$ENV{'request.course.sec'} ne $sec) { next; } |
$env{'request.course.sec'} ne $sec) { next; } |
# if a student without a section don't show any section ones |
# if a student without a section don't show any section ones |
if (!$ENV{'request.role.adv'} && |
if (!$env{'request.role.adv'} && |
!$ENV{'request.course.sec'}) { next; } |
!$env{'request.course.sec'}) { next; } |
$section=&mt('Group/Section').': '.$1; |
$section=&mt('Group/Section').': '.$1; |
$middle=~s/^\[(.*)\]\.//; |
$middle=~s/^\[(.*)\]\.//; |
} |
} |
$middle=~s/\.$//; |
$middle=~s/\.$//; |
my $realm=&mt('All Resources'); |
my $realm=&mt('All Resources'); |
if ($middle=~/^(.+)\_\_\_\(all\)$/) { |
if ($middle=~/^(.+)\_\_\_\(all\)$/) { |
$realm=&mt('Folder/Map').': '.&Apache::lonnet::gettitle($1); |
my $map_url=$1; |
|
if (!$can_see_hidden && !$navmap) { |
|
next; |
|
} |
|
if (!$can_see_hidden) { |
|
my $res = $navmap->getResourceByUrl($map_url); |
|
if ($res && $res->randomout()) { next; } |
|
} |
|
$realm=&mt('Folder/Map').': '.&Apache::lonnet::gettitle($map_url); |
} elsif ($middle) { |
} elsif ($middle) { |
|
if (!$can_see_hidden && !$navmap) { |
|
next; |
|
} |
|
if (!$can_see_hidden) { |
|
my $res = $navmap->getBySymb($middle); |
|
if ($res && $res->randomout()) { next; } |
|
} |
$realm=&mt('Resource').': '.&Apache::lonnet::gettitle($middle); |
$realm=&mt('Resource').': '.&Apache::lonnet::gettitle($middle); |
} |
} |
my $datetype=''; |
my $datetype=''; |
Line 133 sub emptycell {
|
Line 161 sub emptycell {
|
sub normalcell { |
sub normalcell { |
my ($day,$month,$year,$text)=@_; |
my ($day,$month,$year,$text)=@_; |
my $output=''; |
my $output=''; |
foreach (split(/\_\_\_\&\&\&\_\_\_/,$text)) { |
my @items=&order($text); |
if ($_) { |
foreach my $item (@items) { |
|
if ($item) { |
my $internalflag=0; |
my $internalflag=0; |
my ($courseid,$start,$end,@msg)=split(/\@/,$_); |
my ($courseid,$start,$end,$msg)=split(/\@/,$item,4); |
my $msg=join('@',@msg); |
|
if ($msg=~/INTERNAL\:/) { |
if ($msg=~/INTERNAL\:/) { |
$msg=~s/INTERNAL\://gs; |
$msg=~s/INTERNAL\://gs; |
$internalflag=1; |
$internalflag=1; |
} |
} |
my $fullmsg=&mt('Calendar Announcement for ').$ENV{'course.'.$courseid.'.description'}. |
my $fullmsg=&mt('Calendar Announcement for ').$env{'course.'.$courseid.'.description'}. |
'\n'.&Apache::lonlocal::locallocaltime($start); |
'\n'.&Apache::lonlocal::locallocaltime($start); |
if ($start!=$end) { |
if ($start!=$end) { |
$fullmsg.=' - '.&Apache::lonlocal::locallocaltime($end); |
$fullmsg.=' - '.&Apache::lonlocal::locallocaltime($end); |
} |
} |
$fullmsg.=':\n'.$msg; |
$fullmsg.=':\n'.$msg; |
if ($courseid eq $ENV{'request.course.id'}) { |
if ($courseid eq $env{'request.course.id'}) { |
if ((&Apache::lonnet::allowed('srm',$ENV{'request.course.id'})) |
if ((&Apache::lonnet::allowed('srm',$env{'request.course.id'})) |
&& (!$showedcheck{$start.'_'.$end}) |
&& (!$showedcheck{$start.'_'.$end}) |
&& ($ENV{'form.pickdate'} ne 'yes') |
&& ($env{'form.pickdate'} ne 'yes') |
&& (!$internalflag)) { |
&& (!$internalflag)) { |
$output.='<input type="checkbox" name="remove_'.$start.'_'. |
$output.='<input type="checkbox" name="remove_'.$start.'_'. |
$end.'">'; |
$end.'">'; |
Line 175 sub normalcell {
|
Line 203 sub normalcell {
|
sub plaincell { |
sub plaincell { |
my ($text)=@_; |
my ($text)=@_; |
my $output=''; |
my $output=''; |
foreach (split(/\_\_\_\&\&\&\_\_\_/,$text)) { |
my @items=&order($text); |
if ($_) { |
foreach my $item (@items) { |
my ($courseid,$start,$end,@msg)=split(/\@/,$_); |
if ($item) { |
my $msg=join('@',@msg); |
my ($courseid,$start,$end,$msg)=split(/\@/,$item,4); |
my $fullmsg=&mt('Calendar Announcement for ').$ENV{'course.'.$courseid.'.description'}. |
my $fullmsg=&mt('Calendar Announcement for ').$env{'course.'.$courseid.'.description'}. |
'\n'.&Apache::lonlocal::locallocaltime($start); |
'\n'.&Apache::lonlocal::locallocaltime($start); |
if ($start!=$end) { |
if ($start!=$end) { |
$fullmsg.=' - '.&Apache::lonlocal::locallocaltime($end); |
$fullmsg.=' - '.&Apache::lonlocal::locallocaltime($end); |
Line 190 sub plaincell {
|
Line 218 sub plaincell {
|
$fullmsg=&HTML::Entities::encode($fullmsg,'<>&"\''); |
$fullmsg=&HTML::Entities::encode($fullmsg,'<>&"\''); |
$fullmsg=~s/&/\\&/g; |
$fullmsg=~s/&/\\&/g; |
$output.='<a href="javascript:alert('."'$fullmsg'".')">'. |
$output.='<a href="javascript:alert('."'$fullmsg'".')">'. |
substr($msg,0,40).'...</a><br />'; |
substr($msg,0,80).'...</a><br />'; |
} |
} |
} |
} |
return $output; |
return $output; |
Line 199 sub plaincell {
|
Line 227 sub plaincell {
|
sub listcell { |
sub listcell { |
my ($text)=@_; |
my ($text)=@_; |
my $output=''; |
my $output=''; |
foreach (split(/\_\_\_\&\&\&\_\_\_/,$text)) { |
my @items=&order($text); |
if ($_) { |
foreach my $item (@items) { |
my ($courseid,$start,$end,@msg)=split(/\@/,$_); |
if ($item) { |
my $msg=join('@',@msg); |
my ($courseid,$start,$end,$msg)=split(/\@/,$item,4); |
$msg=~s/INTERNAL\://gs; |
$msg=~s/INTERNAL\://gs; |
my $fullmsg=&Apache::lonlocal::locallocaltime($start); |
my $fullmsg=&Apache::lonlocal::locallocaltime($start); |
if ($start!=$end) { |
if ($start!=$end) { |
Line 217 sub listcell {
|
Line 245 sub listcell {
|
return $output; |
return $output; |
} |
} |
|
|
|
sub order { |
|
my ($text)=@_; |
|
my @items = split(/___&&&___/,$text); |
|
sort { |
|
my (undef,$astart,$aend)=split(/\@/,$a); |
|
my (undef,$bstart,$bend)=split(/\@/,$b); |
|
if ($astart != $bstart) { |
|
return $astart <=> $bstart; |
|
} |
|
return $aend <=> $bend; |
|
} @items; |
|
} |
|
|
sub nextday { |
sub nextday { |
my %th=@_; |
my %th=@_; |
$th{'day'}++; |
$th{'day'}++; |
Line 233 sub showday {
|
Line 274 sub showday {
|
$tk-=$oneday; |
$tk-=$oneday; |
$nextday+=$oneday; |
$nextday+=$oneday; |
} |
} |
foreach (keys %allcal) { |
foreach my $item (keys(%allcal)) { |
my ($course,$startdate,$enddate)=($_=~/^(\w+)\@(\d+)\_(\d+)$/); |
my ($course,$startdate,$enddate)=($item=~/^(\w+)\@(\d+)\_(\d+)$/); |
if (($startdate<$nextday) && ($enddate>$tk)) { |
if (($startdate<$nextday) && ($enddate>=$tk)) { |
$outp.='___&&&___'.$course.'@'.$startdate.'@'.$enddate.'@'. |
$outp.='___&&&___'.$course.'@'.$startdate.'@'.$enddate.'@'. |
$allcal{$_}; |
$allcal{$item}; |
} |
} |
} |
} |
unless ($mode) { |
unless ($mode) { |
Line 256 sub showday {
|
Line 297 sub showday {
|
|
|
sub tfont { |
sub tfont { |
my $text=shift; |
my $text=shift; |
if ($ENV{'form.pickdate'} eq 'yes') { |
if ($env{'form.pickdate'} eq 'yes') { |
return '<font size="1">'.$text.'</font>'; |
return '<font size="1">'.$text.'</font>'; |
} else { |
} else { |
return $text; |
return $text; |
Line 265 sub tfont {
|
Line 306 sub tfont {
|
|
|
sub picklink { |
sub picklink { |
my ($text,$day,$month,$year)=@_; |
my ($text,$day,$month,$year)=@_; |
if ($ENV{'form.pickdate'} eq 'yes') { |
if ($env{'form.pickdate'} eq 'yes') { |
return '<a href="javascript:dialin('.$day.','.$month.','.$year.')">'. |
return '<a href="javascript:dialin('.$day.','.$month.','.$year.')">'. |
$text.'</a>'; |
$text.'</a>'; |
} else { |
} else { |
Line 277 sub dialscript {
|
Line 318 sub dialscript {
|
return (<<ENDDIA); |
return (<<ENDDIA); |
<script language="Javascript"> |
<script language="Javascript"> |
function dialin(day,month,year) { |
function dialin(day,month,year) { |
opener.document.$ENV{'form.formname'}.$ENV{'form.element'}\_year.value=year; |
opener.document.$env{'form.formname'}.$env{'form.element'}\_year.value=year; |
var slct=opener.document.$ENV{'form.formname'}.$ENV{'form.element'}\_month; |
var slct=opener.document.$env{'form.formname'}.$env{'form.element'}\_month; |
var i; |
var i; |
for (i=0;i<slct.length;i++) { |
for (i=0;i<slct.length;i++) { |
if (slct.options[i].value==month) { slct.selectedIndex=i; } |
if (slct.options[i].value==month) { slct.selectedIndex=i; } |
} |
} |
opener.document.$ENV{'form.formname'}.$ENV{'form.element'}\_day.value=day; |
opener.document.$env{'form.formname'}.$env{'form.element'}\_day.value=day; |
opener.$ENV{'form.element'}\_checkday(); |
opener.$env{'form.element'}\_checkday(); |
self.close(); |
self.close(); |
} |
} |
</script> |
</script> |
Line 308 sub handler {
|
Line 349 sub handler {
|
['month','year','pickdate','formname','element']); |
['month','year','pickdate','formname','element']); |
# --------------------------------------------------- Decide what month to show |
# --------------------------------------------------- Decide what month to show |
my $year=$todayhash{'year'}; |
my $year=$todayhash{'year'}; |
if ($ENV{'form.year'}) { $year=$ENV{'form.year'}; } |
if ($env{'form.year'}) { $year=$env{'form.year'}; } |
my $month=$todayhash{'month'}; |
my $month=$todayhash{'month'}; |
if ($ENV{'form.month'}) { $month=$ENV{'form.month'}; } |
if ($env{'form.month'}) { $month=$env{'form.month'}; } |
|
|
# ---------------------------------------------- See if we are in pickdate mode |
# ---------------------------------------------- See if we are in pickdate mode |
my $pickdatemode=($ENV{'form.pickdate'} eq 'yes'); |
my $pickdatemode=($env{'form.pickdate'} eq 'yes'); |
my $pickinfo='&pickdate=yes&formname='.$ENV{'form.formname'}. |
my $pickinfo='&pickdate=yes&formname='.$env{'form.formname'}. |
'&element='.$ENV{'form.element'}; |
'&element='.$env{'form.element'}; |
# --------------------------------------------- Find out first day of the month |
# --------------------------------------------- Find out first day of the month |
|
|
my %firstday=&Apache::loncommon::timehash( |
my %firstday=&Apache::loncommon::timehash( |
Line 325 sub handler {
|
Line 366 sub handler {
|
'dlsav' => -1 )); |
'dlsav' => -1 )); |
my $weekday=$firstday{'weekday'}; |
my $weekday=$firstday{'weekday'}; |
# ------------------------------------------------------------ Print the screen |
# ------------------------------------------------------------ Print the screen |
|
my $html=&Apache::lonxml::xmlbegin(); |
$r->print(<<ENDDOCUMENT); |
$r->print(<<ENDDOCUMENT); |
<html> |
$html |
<head> |
<head> |
<title>The LearningOnline Network with CAPA</title> |
<title>The LearningOnline Network with CAPA</title> |
<script> |
<script> |
Line 354 ENDDOCUMENT
|
Line 395 ENDDOCUMENT
|
} |
} |
# does this user have privileges to post, etc? |
# does this user have privileges to post, etc? |
my $allowed=0; |
my $allowed=0; |
if ($ENV{'request.course.id'}) { |
if ($env{'request.course.id'}) { |
$allowed=&Apache::lonnet::allowed('srm',$ENV{'request.course.id'}); |
$allowed=&Apache::lonnet::allowed('srm',$env{'request.course.id'}); |
} |
} |
# does this user have privileges to post to servers? |
# does this user have privileges to post to servers? |
my $serverpost=0; |
my $serverpost=0; |
if ($ENV{'request.role.domain'}) { |
if ($env{'request.role.domain'}) { |
$serverpost=&Apache::lonnet::allowed('psa', |
$serverpost=&Apache::lonnet::allowed('psa', |
$ENV{'request.role.domain'}); |
$env{'request.role.domain'}); |
} else { |
} else { |
$serverpost=&Apache::lonnet::allowed('psa','/'); |
$serverpost=&Apache::lonnet::allowed('psa','/'); |
} |
} |
Line 372 ENDDOCUMENT
|
Line 413 ENDDOCUMENT
|
} |
} |
# ------------------------------------------------------------ Process commands |
# ------------------------------------------------------------ Process commands |
if ($serverpost) { |
if ($serverpost) { |
if ($ENV{'form.serveraction'}) { |
if ($env{'form.serveraction'}) { |
foreach (keys %ENV) { |
foreach my $key (keys(%env)) { |
if ($_=~/^form\.postto\_(\w+)/) { |
if ($key=~/^form\.postto\_(\w+)/) { |
$r->print( |
$r->print( |
'<br />Posting '.$1.': '.&Apache::lonnet::postannounce |
'<br />Posting '.$1.': '.&Apache::lonnet::postannounce |
($1,$ENV{'form.serverannnounce'})); |
($1,$env{'form.serverannnounce'})); |
} |
} |
} |
} |
} |
} |
Line 390 Post announcements to the system login a
|
Line 431 Post announcements to the system login a
|
Check machines:<br /> |
Check machines:<br /> |
SERVERANNOUNCE |
SERVERANNOUNCE |
# list servers |
# list servers |
foreach (sort keys %Apache::lonnet::hostname) { |
foreach my $host (sort(keys(%Apache::lonnet::hostname))) { |
if (&Apache::lonnet::allowed('psa',$Apache::lonnet::hostdom{$_})) { |
if (&Apache::lonnet::allowed('psa',$Apache::lonnet::hostdom{$host})) { |
$r->print ('<br /><input type="checkbox" name="postto_'.$_.'" /> '. |
$r->print ('<br /><input type="checkbox" name="postto_'.$host.'" /> '. |
$_.' <tt>'.$Apache::lonnet::hostname{$_}.'</tt> '. |
$host.' <tt>'.$Apache::lonnet::hostname{$host}.'</tt> '. |
'<a href="http://'.$Apache::lonnet::hostname{$_}. |
'<a href="http://'.$Apache::lonnet::hostname{$host}. |
'/announcement.txt" target="annowin">current</a>'); |
'/announcement.txt" target="annowin">current</a>'); |
} |
} |
} |
} |
Line 402 SERVERANNOUNCE
|
Line 443 SERVERANNOUNCE
|
'<br /><input type="submit" name="serveraction" value="Post"></form><hr />'); |
'<br /><input type="submit" name="serveraction" value="Post"></form><hr />'); |
} |
} |
if ($allowed) { |
if ($allowed) { |
my $coursenum=$ENV{'course.'.$ENV{'request.course.id'}.'.num'}; |
my $coursenum=$env{'course.'.$env{'request.course.id'}.'.num'}; |
my $coursedom=$ENV{'course.'.$ENV{'request.course.id'}.'.domain'}; |
my $coursedom=$env{'course.'.$env{'request.course.id'}.'.domain'}; |
# ----------------------------------------------------- Store new submitted one |
# ----------------------------------------------------- Store new submitted one |
if ($ENV{'form.action'} eq 'new') { |
if ($env{'form.action'} eq 'new') { |
my $startdate = |
my $startdate = |
&Apache::lonhtmlcommon::get_date_from_form('startdate'); |
&Apache::lonhtmlcommon::get_date_from_form('startdate'); |
my $enddate = |
my $enddate = |
Line 419 SERVERANNOUNCE
|
Line 460 SERVERANNOUNCE
|
} |
} |
&Apache::lonnet::put('calendar',{ |
&Apache::lonnet::put('calendar',{ |
$startdate.'_'.$enddate => |
$startdate.'_'.$enddate => |
$ENV{'form.msg'} },$coursedom,$coursenum); |
$env{'form.msg'} },$coursedom,$coursenum); |
|
if ($env{'form.rsspost'}) { |
|
&Apache::lonrss::addentry($coursenum,$coursedom,'Course_Announcements', |
|
&mt('Event from [_1] to [_2]', |
|
&Apache::lonlocal::locallocaltime($startdate), |
|
&Apache::lonlocal::locallocaltime($enddate)), |
|
$env{'form.msg'},'/adm/announcements','public'); |
|
} |
} |
} |
# ---------------------------------------------------------------- Remove items |
# ---------------------------------------------------------------- Remove items |
if ($ENV{'form.action'} eq 'del') { |
if ($env{'form.action'} eq 'del') { |
my @delwhich=(); |
my @delwhich=(); |
foreach (keys %ENV) { |
foreach my $key (keys(%env)) { |
if ($_=~/^form\.remove\_(.+)$/) { |
if ($key=~/^form\.remove\_(.+)$/) { |
push(@delwhich,$1); |
push(@delwhich,$1); |
} |
} |
} |
} |
Line 440 SERVERANNOUNCE
|
Line 488 SERVERANNOUNCE
|
} |
} |
# ----------------------------------------------------- Summarize all calendars |
# ----------------------------------------------------- Summarize all calendars |
my %allcal=(); |
my %allcal=(); |
foreach (&Apache::loncommon::findallcourses()) { |
foreach my $course (&Apache::loncommon::findallcourses()) { |
%allcal=(%allcal,&readcalendar($_)); |
%allcal=(%allcal,&readcalendar($course)); |
} |
} |
|
|
# ------------------------------- Initialize table and forward backward buttons |
# ------------------------------- Initialize table and forward backward buttons |