Diff for /loncom/interface/lonsyllabus.pm between versions 1.48 and 1.55

version 1.48, 2006/03/15 19:41:26 version 1.55, 2006/10/23 18:48:47
Line 38  use Apache::lonannounce; Line 38  use Apache::lonannounce;
 use Apache::lonlocal;  use Apache::lonlocal;
 use Apache::lonhtmlcommon;  use Apache::lonhtmlcommon;
 use Apache::lonspeller();  use Apache::lonspeller();
   use HTML::Entities();
   
 sub handler {  sub handler {
     my $r = shift;      my $r = shift;
Line 56  sub handler { Line 57  sub handler {
     if ($homeserver eq 'no_host') {      if ($homeserver eq 'no_host') {
         &Apache::loncommon::content_type($r,'text/html');          &Apache::loncommon::content_type($r,'text/html');
         $r->send_http_header;          $r->send_http_header;
         $r->print(&Apache::loncommon::startpage('No syllabus available').        &Apache::loncommon::simple_error_page($r,'No syllabus available',
   &mt('No syllabus available').        'No syllabus available');
   &Apache::loncommon::end_page());  
         return OK;          return OK;
     }      }
 # ------------------------------------- There is such a course, get environment  # ------------------------------------- There is such a course, get environment
     my %courseenv=&Apache::lonnet::dump('environment',$cdom,$cnum);      my %courseenv=&Apache::lonnet::dump('environment',$cdom,$cnum);
   
 # ------------------------------------------------------------ Print the screen  # ------------------------------------------------------------ Print the screen
     my $feedurl='http://'.$ENV{'HTTP_HOST'}.'/public/'.$cdom.'/'.$cnum.'/Course_Announcements.rss';  
     if ($target ne 'tex') {      my $rss_link =
  my $html=&Apache::lonxml::xmlbegin();   &Apache::lonrss::rss_link('http://'.$ENV{'HTTP_HOST'}.'/public/'.$cdom.'/'.$cnum.'/Course_Announcements.rss');
  my $head=&Apache::loncommon::headtag('The LearningOnline Network with CAPA');  
  $r->print(<<ENDDOCUMENT);      if ($target eq 'tex') {
 $html  
 $head  
 <link rel="alternate" type="application/rss+xml" title="Course Announcements" href="$feedurl" />  
 ENDDOCUMENT  
     } else {  
  $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));   $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));
     }       } 
 # ----------------------------------------------------- Force menu registration  
     my $addentries='';  
     if ($env{'form.register'}) {  
        $addentries=' onLoad="'.&Apache::lonmenu::loadevents().  
            '" onUnload="'.&Apache::lonmenu::unloadevents().'"';  
        $r->print(&Apache::lonmenu::registerurl(1));  
     }  
 # -------------------------------------------------- Let's see who handles this  # -------------------------------------------------- Let's see who handles this
     my $externalsyllabus=$courseenv{'externalsyllabus'};      my $externalsyllabus=$courseenv{'externalsyllabus'};
   
     if ($externalsyllabus=~/\w/) {      if ($externalsyllabus=~/\w/) {
        $r->print(&Apache::loncommon::endheadtag());  
        if ($env{'form.wrapperdisplay'} eq 'menu') {         if ($env{'form.wrapperdisplay'} eq 'menu') {
 #     $r->print(&Apache::lonwrapper::simple_menu());
 # Producing the menu buttons         } else {    
 #     $r->print(&Apache::lonwrapper::wrapper("/public/$cdom/$cnum/syllabus?wrapperdisplay=menu",
            $r->print('<body bgcolor="#FFFFFF">'.     $externalsyllabus));
      &Apache::lonmenu::menubuttons(1,'web',1).         }
      &Apache::loncommon::end_page());         return OK;
         } else {  
            if ($env{'browser.interface'} eq 'textual') {  
 #  
 # ssi-based rendering for text-based interface  
 #  
                $r->print('<body bgcolor="#FFFFFF">'.  
  &Apache::lonmenu::menubuttons(1).  
  &Apache::lonnet::ssi_body($externalsyllabus).  
  &Apache::loncommon::end_page());  
            } elsif ($env{'environment.remote'} eq 'off') {  
 #  
 # This is inline remote  
 #   
                $r->print(<<ENDDOCUMENTINL);  
 <frameset rows="180,*" border="0" $addentries>  
 <frame src="/public/$cdom/$cnum/syllabus?wrapperdisplay=menu">  
 <frame src="$externalsyllabus">  
 </frameset>  
 </html>  
 ENDDOCUMENTINL  
           } else {  
 #  
 # frame-based rendering for graphical interface  
 #  
                $r->print(<<ENDDOCUMENT);  
 <frameset rows="1,*" border="0" $addentries>  
 <frame src="/adm/rat/empty.html">  
 <frame src="$externalsyllabus">  
 </frameset>  
 </html>  
 ENDDOCUMENT  
            }  
         }  
         return OK;  
      }        } 
   
 # ------------------------------ The buck stops here: internal syllabus display  # ------------------------------ The buck stops here: internal syllabus display
Line 157  ENDDOCUMENT Line 112  ENDDOCUMENT
                 
 # ----------------------------------------------------------------- Make header   # ----------------------------------------------------------------- Make header 
     if ($target ne 'tex') {      if ($target ne 'tex') {
  $r->print(&Apache::lonhtmlcommon::htmlareaheaders().   my $start_page = 
   &Apache::loncommon::endheadtag().      &Apache::loncommon::start_page("Syllabus", $rss_link,
   &Apache::loncommon::bodytag("Syllabus",$forcestudent,$addentries,'',$cdom,$env{'form.register'}));     {'function'       => $forcestudent,
  $r->print('<h1>'.$courseenv{'description'}.'</h1><h3>'.      'domain'         => $cdom,
       'force_register' =>
    $env{'form.register'},});
   
    $r->print($start_page.'<h1>'.$courseenv{'description'}.'</h1><h3>'.
                  $Apache::lonnet::domaindescription{$cdom}.'</h3>');                   $Apache::lonnet::domaindescription{$cdom}.'</h3>');
     } else {      } else {
  $r->print('\noindent{\large\textbf{'.$courseenv{'description'}.'}}\\\\\\\\\textbf{'.   $r->print('\noindent{\large\textbf{'.$courseenv{'description'}.'}}\\\\\\\\\textbf{'.
                  $Apache::lonnet::domaindescription{$cdom}.'}\\\\');                   $Apache::lonnet::domaindescription{$cdom}.'}\\\\');
     }      }
 # -------------------------------------------------------------- Announcements?  # -------------------------------------------------------------- Announcements?
       my $day = &Apache::lonannounce::showday(time,2,
    &Apache::lonannounce::readcalendar($cdom.'_'.$cnum));
     if ($target ne 'tex') {      if ($target ne 'tex') {
  $r->print(&Apache::lonannounce::showday(time,2,   $r->print($day. &Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit));
        &Apache::lonannounce::readcalendar($cdom.'_'.$cnum)).  
                        &Apache::lonrss::advertisefeeds($cnum,$cdom));  
     } else {      } else {
  $r->print(&Apache::lonxml::xmlparse($r,'tex',   $r->print(&Apache::lonxml::xmlparse($r,'tex',$day));
        &Apache::lonannounce::showday(time,2,  
                        &Apache::lonannounce::readcalendar($cdom.'_'.$cnum))));  
     }      }
   
 # -------------------------------------------------------- Get course personnel  # -------------------------------------------------------- Get course personnel
     my %coursepersonnel=&Apache::lonnet::get_course_adv_roles($cdom.'/'.$cnum);      my %coursepersonnel=&Apache::lonnet::get_course_adv_roles($cdom.'/'.$cnum);
     if ($target ne 'tex') {      if ($target ne 'tex') {
Line 220  ENDDOCUMENT Line 178  ENDDOCUMENT
 # ----------------------------------------------------- Only if not public call  # ----------------------------------------------------- Only if not public call
     if ($env{'user.environment'}) {      if ($env{'user.environment'}) {
 # does this user have privileges to post, etc?  # does this user have privileges to post, etc?
        if ($env{'request.course.id'}) {         if ($env{'request.course.id'}
      && $cdom eq $env{'course.'.$env{'request.course.id'}.'.domain'}
      && $cnum eq $env{'course.'.$env{'request.course.id'}.'.num'}) {
           $allowed=&Apache::lonnet::allowed('mdc',$env{'request.course.id'});            $allowed=&Apache::lonnet::allowed('mdc',$env{'request.course.id'});
   $privileged=$allowed;    $privileged=$allowed;
   if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {    if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {
Line 246  ENDDOCUMENT Line 206  ENDDOCUMENT
   }    }
       }        }
        if (($allowed) && ($env{'form.storesyl'})) {         if (($allowed) && ($env{'form.storesyl'})) {
    foreach (keys %syllabusfields) {     foreach my $syl_field (keys(%syllabusfields)) {
                my $field=$env{'form.'.$_};                 my $field=$env{'form.'.$syl_field};
        chomp($field);         chomp($field);
                $field=~s/\s+$//s;                 $field=~s/\s+$//s;
        $field=~s/^\s+//s;         $field=~s/^\s+//s;
        $field=~s/\<br\s*\/*\>$//s;         $field=~s/\<br\s*\/*\>$//s;
        $field=&Apache::lonfeedback::clear_out_html($field,1);         $field=&Apache::lonfeedback::clear_out_html($field,1);
        $syllabus{$_}=$field;         $syllabus{$syl_field}=$field;
                if ($_ eq 'lll_includeurl') { # clean up included URLs                 if ($syl_field eq 'lll_includeurl') { # clean up included URLs
                   my $field='';                    my $field='';
           foreach (split(/\n/,$syllabus{$_})) {            foreach my $value (split(/\n/,$syllabus{$syl_field})) {
       my $url=$_;        my $url=$value;
 # get rid of leading and trailing spaces  # get rid of leading and trailing spaces
                       $url=~s/^\s+//;                        $url=~s/^\s+//;
                       $url=~s/\s+$//;                        $url=~s/\s+$//;
                       if ($url=~/^http\:\/\/([^\/]+)\/(.+)$/) {                        if ($url=~m|^http://([^/]+)/(.+)$|) {
     my $host = $1;
                           my $remainder=$2;                            my $remainder=$2;
 # remove the hostname from internal URLs  # remove the hostname from internal URLs
           foreach (keys %Apache::lonnet::hostname) {            foreach my $possible_host (keys(%Apache::lonnet::hostname)) {
                               if ($1=~/$Apache::lonnet::hostname{$_}/i) {                                if ($possible_host =~
        /\Q$Apache::lonnet::hostname{$host}\E/i) {
          $url=$remainder;           $url=$remainder;
       }        }
           }            }
Line 279  ENDDOCUMENT Line 241  ENDDOCUMENT
           $field.=$url."\n";            $field.=$url."\n";
                       }                        }
   }    }
                   $syllabus{$_}=$field;                    $syllabus{$syl_field}=$field;
       }        }
            }             }
            $syllabus{'uploaded.domain'}=$env{'user.domain'};             $syllabus{'uploaded.domain'}=$env{'user.domain'};
Line 310  ENDDOCUMENT Line 272  ENDDOCUMENT
      '<input type="hidden" name="forceedit" value="edit" />');       '<input type="hidden" name="forceedit" value="edit" />');
        }         }
        my @htmlids=();         my @htmlids=();
        foreach (sort keys %syllabusfields) {         foreach my $field (sort(keys(%syllabusfields))) {
           if (($syllabus{$_}=~/\w/) || ($allowed)) {     if (($syllabus{$field}=~/\w/) || ($allowed)) {
               my $message=$syllabus{$_};         my $message=$syllabus{$field};
               if ($_ eq 'lll_includeurl') { # this is the "included" field         if ($field eq 'lll_includeurl') { # this is the "included" field
   my $urls=$message;     my $urls=$message;
                   $message='';     $message='';
                   foreach my $filelink (split(/\n/,$urls)) {     foreach my $filelink (split(/\n/,$urls)) {
       my $output='';         my $output='';
 # embed style?  # embed style?
       my ($curfext)=($filelink=~/\.([^\.]+)$/);         my ($curfext)=($filelink=~/\.([^\.]+)$/);
                       my $embstyle=&Apache::loncommon::fileembstyle($curfext);         my $embstyle=&Apache::loncommon::fileembstyle($curfext);
               if (($embstyle eq 'ssi') || ($curfext=~/\/$/)) {         if (($embstyle eq 'ssi') || ($curfext=~/\/$/)) {
 # make ssi call and remove everything but the body contents  # make ssi call and remove everything but the body contents
   $output=&Apache::lonnet::ssi_body($filelink);     $output=&Apache::lonnet::ssi_body($filelink);
               } elsif ($embstyle eq 'img') {         } elsif ($embstyle eq 'img') {
 # embed as an image  # embed as an image
                          $output='<img src="'.$filelink.'" />';     $output='<img src="'.$filelink.'" />';
       }         }
       if ($target ne 'tex') {         if ($target ne 'tex') {
   $message.='<p>'.$output.'</p>';     $message.='<p>'.$output.'</p>';
       } else {         } else {
   $message.=' '.&Apache::lonxml::xmlparse($r,'tex','<p>'.$output.'</p>').' ';     $message.=' '.&Apache::lonxml::xmlparse($r,'tex','<p>'.$output.'</p>').' ';
       }               }      
                   }     }
                   if ($allowed) {     if ($allowed) {
                      $r->print('<h3>'.$syllabusfields{$_}.         $r->print('<h3>'.$syllabusfields{$field}.
           &Apache::loncommon::help_open_topic('Syllabus_URLs').'</h3>'.   &Apache::loncommon::help_open_topic('Syllabus_URLs').'</h3>'.
   '<p><a href="'.$r->uri.'?forcestudent=1"><font size="+1">'.&mt('Show Public View').'</font></a>'.   '<p><a href="'.$r->uri.'?forcestudent=1"><font size="+1">'.&mt('Show Public View').'</font></a>'.
  &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView').'</p>');   &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView').'</p>');
  } else {     } else {
                   $r->print($message);         $r->print($message);
                  }      } 
               } else {         } else {
   &Apache::lonfeedback::newline_to_br(\$message);     &Apache::lonfeedback::newline_to_br(\$message);
                  $message     $message =~s|(https*://[^\s]+)|<a href="$1"><tt>$1</tt></a>/g;
            =~s/(https*\:\/\/[^\s]+)/\<a href=\"$1\"\>\<tt\>$1\<\/tt\>\<\/a\>/g;     if ($allowed) {
  if ($allowed) {         $message=&Apache::lonspeller::markeduptext($message);
      $message=&Apache::lonspeller::markeduptext($message);     }
  }     $message=&Apache::lontexconvert::msgtexconverted($message);
          $message=&Apache::lontexconvert::msgtexconverted($message);     if ($target ne 'tex') {
  if ($target ne 'tex') {         $r->print('<h3>'.$syllabusfields{$field}.'</h3><blockquote>'.
      $r->print('<h3>'.$syllabusfields{$_}.'</h3><blockquote>'.   $message.'</blockquote>');
                                $message.'</blockquote>');     } else {
  } else {         $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'.
      $r->print('\\\\\textbf{'.$syllabusfields{$_}.'}\\\\'.   &Apache::lonxml::xmlparse($r,'tex',$message).'\\\\');
        &Apache::lonxml::xmlparse($r,'tex',$message).'\\\\');     }
  }     push(@htmlids,$field);
  push @htmlids,$_;         }
      }         if ($allowed) {
               if ($allowed) {     $r->print('<br /><textarea cols="80" rows="12" name="'.$field.'" id="'.$field.'">'.
                  $r->print(       &HTML::Entities::encode($syllabus{$field},'"&<>').
    '<br /><textarea cols="80" rows="12" name="'.$_.'" id="'.$_.'">'.       '</textarea> <input type="submit" name="storesyl" value="Store" />');
    $syllabus{$_}.         }
            '</textarea> <input type="submit" name="storesyl" value="Store" />');     }
       }  
   }  
        }         }
        if ($allowed) {         if ($allowed) {
    $r->print('</form>'.     $r->print('</form>'.

Removed from v.1.48  
changed lines
  Added in v.1.55


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>