--- loncom/interface/lonrss.pm 2005/11/18 19:11:06 1.3 +++ loncom/interface/lonrss.pm 2006/03/16 20:03:11 1.11 @@ -1,7 +1,7 @@ # The LearningOnline Network # RSS Feeder # -# $Id: lonrss.pm,v 1.3 2005/11/18 19:11:06 albertel Exp $ +# $Id: lonrss.pm,v 1.11 2006/03/16 20:03:11 albertel Exp $ # # Copyright Michigan State University Board of Trustees # @@ -38,7 +38,7 @@ use Apache::lonhtmlcommon; sub filterfeedname { my $filename=shift; - $filename=~s/\.rss$//; + $filename=~s/(\_rss\.html|\.rss)$//; $filename=~s/\W//g; return $filename; } @@ -74,14 +74,20 @@ sub renamefeed { } sub advertisefeeds { - my ($uname,$udom)=@_; + my ($uname,$udom,$edit)=@_; my $feeds=''; my %feednames=&Apache::lonnet::dump('nohist_all_rss_feeds',$udom,$uname); + my $mode='public'; + if ($edit) { + $mode='adm'; + } foreach my $feed (sort(keys(%feednames))) { if ($feed!~/^error\:/) { - my $url='feed://'.$ENV{'HTTP_HOST'}.'/public/'.$udom.'/'.$uname.'/'.$feed.'.rss'; - $feeds.='<li><a href="'.$url.'">'. - $feednames{$feed}.'</a><br /><tt>'.$url.'</tt></li>'; + my $feedurl='feed://'.$ENV{'HTTP_HOST'}.'/public/'.$udom.'/'.$uname.'/'.$feed.'.rss'; + my $htmlurl='http://'.$ENV{'HTTP_HOST'}.'/'.$mode.'/'.$udom.'/'.$uname.'/'.$feed.'_rss.html'; + $feeds.='<li>'.$feednames{$feed}. + '<br />'.($edit?&mt('Edit'):'HTML').': <a href="'.$htmlurl.'"><tt>'.$htmlurl.'</tt></a>'. + ($edit?'':'<br />RSS: <a href="'.$feedurl.'"><tt>'.$feedurl.'</tt></a>').'</li>'; } } if ($feeds) { @@ -132,23 +138,64 @@ sub changestatus { } } +sub changed_js { + return <<ENDSCRIPT; +<script type="text/javascript"> + function changed(tform,id) { + tform.elements[id+"_modified"].checked=true; + } +</script> +ENDSCRIPT +} + sub handler { - my $r = shift; - &Apache::loncommon::content_type($r,'application/rss+xml'); + my ($r) = @_; + + my $edit=0; + my $html=0; + my (undef,$mode,$udom,$uname,$filename)=split(/\//,$r->uri); + if (($mode eq 'adm') && ($env{'user.name'} eq $uname) && ($env{'user.domain'} eq $udom)) { + $edit=1; + $html=1; + } + if ($filename=~/\.html$/) { + $html=1; + } + if ($html) { + &Apache::loncommon::content_type($r,'text/html'); + } else { +# Workaround Mozilla/Firefox +# &Apache::loncommon::content_type($r,'application/rss+xml'); + &Apache::loncommon::content_type($r,'text/xml'); + } $r->send_http_header; return OK if $r->header_only; - my (undef,undef,$udom,$uname,$filename)=split(/\//,$r->uri); my $filterfeedname=&filterfeedname($filename); my $feedname=&feedname($filename); my $displayfeedname=&displayfeedname($filename,$uname,$udom); - $r->print("<rss version='2.0' xmlns:dc='http://purl.org/dc/elements/1.1'>\n<channel>". - "\n<link>http://".$ENV{'HTTP_HOST'}.'/</link>'. - "\n<description>".&mt('An RSS Feed provided by the LON-CAPA Learning Content Management System').'</description>'); + if ($html) { + $r->print(&Apache::lonxml::xmlbegin(). + &Apache::loncommon::head($displayfeedname). + &Apache::loncommon::bodytag($displayfeedname,'','','',$udom, + $env{'form.register'}). + &changed_js()); + + } else { + $r->print("<rss version='2.0' xmlns:dc='http://purl.org/dc/elements/1.1'>\n<channel>". + "\n<link>http://".$ENV{'HTTP_HOST'}.'/public/'.$udom.'/'.$uname.'/'. + $filterfeedname.'_rss.html</link>'. + "\n<description>". + &mt('An RSS Feed provided by the LON-CAPA Learning Content Management System'). + '</description>'); + } # Is this user for real? - my $homeserver=&Apache::lonnet::homeserver($uname,$udom); + my $homeserver=&Apache::lonnet::homeserver($uname,$udom); + if ($html) { + $r->print(&advertisefeeds($uname,$udom,$edit)); + } if ($homeserver eq 'no_host') { - $r->print('<title>'.&mt('No feed available').'</title>'); + $r->print(($html?'<h3>':'<title>').&mt('No feed available').($html?'</h3>':'</title>')); } else { # Course or user? my $name=''; @@ -158,7 +205,13 @@ sub handler { } else { $name=&Apache::loncommon::nickname($uname,$udom); } - $r->print("\n<title>".&mt('LON-CAPA RSS Feed "[_1]" for [_2]',$displayfeedname,$name).'</title>'); + $r->print("\n". + ($html?'<h3>':'<title>'). + &mt('LON-CAPA Feed "[_1]" for [_2]',$displayfeedname,$name). + ($html?'</h3>'.($edit?'<form method="post"><br />'. + &mt('Name of blog/journal'). + ': <input type="text" size="50" name="newblogname" value="'. + $displayfeedname.'" />':'').'<ul>':'</title>')); # Render private items? my $viewpubliconly=1; if (($env{'user.name'} eq $uname) && ($env{'user.domain'} eq $udom)) { @@ -166,25 +219,60 @@ sub handler { } # Get feed items my %newsfeed=&Apache::lonnet::dump($feedname,$udom,$uname); - foreach $entry (sort(keys(%newsfeed))) { + foreach my $entry (sort(keys(%newsfeed))) { if ($entry=~/^(\d+)\_status$/) { my $id=$1; - if (($newsfeed{$id.'_status'} ne 'public') && ($viewpubliconly)) { next; } - if ($newsfeed{$id.'_status'} eq 'hidden') { next; } - $r->print("\n<item>\n<title>".$newsfeed{$id.'_title'}."</title>\n<description>". - $newsfeed{$id.'_description'}."</description>\n<link>"."http://".$ENV{'HTTP_HOST'}. - $newsfeed{$id.'_link'}."</link>\n"); - if ($newsfeed{$id.'_enclosureurl'}) { - $r->print("\n<enclosure url='".$newsfeed{$id.'_enclosureurl'}."' length='".$newsfeed{$id.'_enclosurelength'}. - "' type='".$newsfeed{$id.'_enclosuretype'}."' />"); + if ($edit) { + my %lt=&Apache::lonlocal::texthash('public' => 'public', + 'private' => 'private', + 'hidden' => 'hidden', + 'delete' => 'delete', + 'store' => 'Store changes'); + my %status=(); + $status{$newsfeed{$id.'_status'}}='checked="checked"'; + $r->print(<<ENDEDIT); +<li> +<label><input name='$id\_modified' type='checkbox' /> $lt{'store'}</label> + +<label><input name='$id\_status' type="radio" value="public" $status{'public'} onClick="changed(this.form,'$id');" /> $lt{'public'}</label> + +<label><input name='$id\_status' type="radio" value="private" $status{'private'} onClick="changed(this.form,'$id');" /> $lt{'private'}</label> + +<label><input name='$id\_status' type="radio" value="hidden" $status{'hidden'} onClick="changed(this.form,'$id');" /> $lt{'hidden'}</label> + +<label><input name='$id\_status' type="radio" value="delete" onClick="changed(this.form,'$id');" /> $lt{'delete'}</label> +<br /> +<input name='$id\_title' type='text' size='80' value='$newsfeed{$id.'_title'}' onChange="changed(this.form,'$id');" /><br /> +<textarea name='$id\_description' rows="6" cols="80" onChange="changed(this.form,'$id');">$newsfeed{$id.'_description'}</textarea><br /> +<input name='$id\_link' type='text' size='80' value='$newsfeed{$id.'_link'}' onChange="changed(this.form,'$id');" /> +<hr /></li> +ENDEDIT + } else { + if (($newsfeed{$id.'_status'} ne 'public') && ($viewpubliconly)) { next; } + if ($newsfeed{$id.'_status'} eq 'hidden') { next; } + $r->print("\n".($html?"\n<li><b>":"<item>\n<title>").$newsfeed{$id.'_title'}. + ($html?"</b><br />\n":"</title>\n<description>"). + $newsfeed{$id.'_description'}. + ($html?"<br />\n<a href='":"</description>\n<link>"). + "http://".$ENV{'HTTP_HOST'}. + $newsfeed{$id.'_link'}. + ($html?("'>".&mt('Read more')."</a><br />\n"):"</link>\n")); + if ($newsfeed{$id.'_enclosureurl'}) { + $r->print(($html?"<a href='":"\n<enclosure url='"). + $newsfeed{$id.'_enclosureurl'}."' length='".$newsfeed{$id.'_enclosurelength'}. + "' type='".$newsfeed{$id.'_enclosuretype'}.($html?"'>".&mt('Enclosure')."</a>":"' />")); + } + if ($html) { + $r->print("\n<hr /></li>\n"); + } else { + $r->print("\n<guid isPermaLink='false'>".$id.$filterfeedname.'_'.$udom.'_'.$uname."</guid></item>\n"); + } } - $r->print("\n<guid isPermaLink='false'>".$id.$filterfeedname.'_'.$udom.'_'.$uname."</guid></item>\n"); } } } - $r->print("\n</channel></rss>\n"); + $r->print("\n".($html?'</ul>'.($edit?'<input type="submit" value="'.&mt('Store Marked Changes').'" /></form>':'').&Apache::loncommon::end_page():'</channel></rss>'."\n")); return OK; } - 1; __END__