Diff for /loncom/interface/lonsyllabus.pm between versions 1.81 and 1.88

version 1.81, 2009/03/01 13:23:12 version 1.88, 2009/04/28 14:43:06
Line 69  sub handler { Line 69  sub handler {
   
     if ($target eq 'tex') {      if ($target eq 'tex') {
  $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));   $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}));
     }       }
 # -------------------------------------------------- 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/) {
   
        if ($env{'form.wrapperdisplay'} eq 'menu') {         if ($env{'form.wrapperdisplay'} eq 'menu') {
    $r->print(&Apache::lonwrapper::simple_menu());     $r->print(&Apache::lonwrapper::simple_menu());
        } else {             } else {
    $r->print(&Apache::lonwrapper::wrapper("/public/$cdom/$cnum/syllabus?wrapperdisplay=menu",     $r->print(&Apache::lonwrapper::wrapper("/public/$cdom/$cnum/syllabus?wrapperdisplay=menu",
    $externalsyllabus));     $externalsyllabus));
        }         }
        return OK;         return OK;
      }        }
   
 # ------------------------------ The buck stops here: internal syllabus display  # ------------------------------ The buck stops here: internal syllabus display
 # --------------------------------------------------------- The syllabus fields  # --------------------------------------------------------- The syllabus fields
Line 107  sub handler { Line 107  sub handler {
     if ($env{'form.forcestudent'}) { $forcestudent='student'; };      if ($env{'form.forcestudent'}) { $forcestudent='student'; };
     my $forceedit='';      my $forceedit='';
     if ($env{'form.forceedit'}) { $forceedit='edit'; }      if ($env{'form.forceedit'}) { $forceedit='edit'; }
          
 # ----------------------------------------------------------------- Make header   # ----------------------------------------------------------------- Make header
     if ($target ne 'tex') {      if ($target ne 'tex') {
  my $rss_link = &Apache::lonrss::rss_link($cnum,$cdom);   my $rss_link = &Apache::lonrss::rss_link($cnum,$cdom);
         my $js;          my $js;
Line 139  function getIndexByName(item) { Line 139  function getIndexByName(item) {
   
 ENDSCRIPT  ENDSCRIPT
         }          }
  my $start_page =    my $start_page =
     &Apache::loncommon::start_page("Syllabus", $rss_link.$js,      &Apache::loncommon::start_page("Syllabus", $rss_link.$js,
    {'function'       => $forcestudent,     {'function'       => $forcestudent,
     'domain'         => $cdom,      'domain'         => $cdom,
Line 161  ENDSCRIPT Line 161  ENDSCRIPT
               ({href=>$r->uri,                ({href=>$r->uri,
                text=>"Course syllabus"});                 text=>"Course syllabus"});
             $r->print(&Apache::lonhtmlcommon::breadcrumbs());              $r->print(&Apache::lonhtmlcommon::breadcrumbs());
         }          }
   
     }      }
 # ---------------------------------------------------------- Load syllabus info  # ---------------------------------------------------------- Load syllabus info
     my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum);      my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum);
Line 182  ENDSCRIPT Line 182  ENDSCRIPT
       $forcestudent='student';        $forcestudent='student';
   }    }
           if ($forcestudent or $target eq 'tex') { $allowed=0; }            if ($forcestudent or $target eq 'tex') { $allowed=0; }
        }             }
        if (($allowed) && ($env{'form.storesyl'})) {         if (($allowed) && ($env{'form.storesyl'})) {
    foreach my $syl_field (keys(%syllabusfields)) {     foreach my $syl_field (keys(%syllabusfields)) {
                my $field=$env{'form.'.$syl_field};                 my $field=$env{'form.'.$syl_field};
Line 229  ENDSCRIPT Line 229  ENDSCRIPT
            &Apache::lonnet::put('syllabus',\%syllabus,$cdom,$cnum);             &Apache::lonnet::put('syllabus',\%syllabus,$cdom,$cnum);
        }         }
     }      }
 #-Pritn Help Text  
   #---------------------Print External URL Syllabus Info
   if( ($allowed) && ($target ne 'tex') ) {
    my $protocol = $Apache::lonnet::protocol{$homeserver};
     $protocol = 'http' if ($protocol ne 'https');
           $r->print('<p class="LC_info">'
                    .&mt('This syllabus can be publicly viewed at [_1]'
                        ,'<tt>'.$protocol.'://'.&Apache::lonnet::hostname($homeserver).$r->uri.'</tt>')
                    .'&nbsp;'.&Apache::loncommon::help_open_topic('Syllabus_ExtLink')
                    .'</p>'
                    .'<p class="LC_info">'
                    .&mt('Instead of using this template you can specify an external URL as Syllabus in the [_1]Course Parameters[_2].'
                        ,'<a href="/adm/parmset?action=crsenv">','</a>')
                    .'</p>'
           );
   }
   
   #-Print Help Text
 if ($target ne 'tex') {  if ($target ne 'tex') {
  if($allowed){    if($allowed){
  $r->print(&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')));   $r->print(&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')));
  }   }
 }  }
   #----------Print last update
    my $lastmod=$syllabus{'uploaded.lastmodified'};
          $lastmod=($lastmod?&Apache::lonlocal::locallocaltime($lastmod):&mt('never'));
          my $who = &Apache::loncommon::aboutmewrapper(
                       &Apache::loncommon::plainname($syllabus{'uploaded.name'},
                        $syllabus{'uploaded.domain'}),$syllabus{'uploaded.name'},
                        $syllabus{'uploaded.domain'});
    if ($target ne 'tex') {
      $r->print('<div class="LC_info">'.&mt('Last updated').': '.
        $lastmod . ' '.
        ($who ? &mt('by').' '.$who
                              : '' ) . 
                '</div>' );
        
          } else {
      $r->print('\\\\ '.&mt('Last updated').': '.$lastmod.' '.
        ($who? &mt('by').'\\\\ '.
               &Apache::loncommon::plainname($syllabus{'uploaded.name'},$syllabus{'uploaded.domain'})
             :'')
        .'\\\\');
          }
 #--------Functions  #--------Functions
 if ($target ne 'tex') {  if ($target ne 'tex') {
  if($allowed || $privileged){   if($allowed || $privileged){
  &Apache::lontemplate::print_start_page_functions($r);                  $r->print(&Apache::lontemplate::start_functionslist());
  if($allowed){   if($allowed){
  &Apache::lontemplate::print_functions_content($r,'<a href="'.$r->uri.'?forcestudent=1">'.&mt('Show Public View').'</a>'.&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView'));                            $r->print(&Apache::lontemplate::item_functionslist(
                           '<a href="'.$r->uri.'?forcestudent=1">'.&mt('Show Public View').'</a>'
                          .&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView')));
  }elsif($privileged){   }elsif($privileged){
  &Apache::lontemplate::print_functions_content($r,'<a href="'.$r->uri.'?forceedit=1">'.&mt('Edit').'</a>');                       $r->print(&Apache::lontemplate::item_functionslist(
                           '<a href="'.$r->uri.'?forceedit=1">'.&mt('Edit').'</a>'));
  }   }
  &Apache::lontemplate::print_end_page_functions($r);                  $r->print(&Apache::lontemplate::end_functionslist());
  }   }
  }   }
 #----------------------------Print Headtitle  #----------------------------Print Headtitle
 if($target ne 'tex'){  if($target ne 'tex'){
  $r->print('<h1>'.$courseenv{'description'}.'</h1>');   $r->print('<h1>'.$courseenv{'description'}.'</h1>');
  $r->print('<h3>'.  &Apache::lonnet::domain($cdom,'description').'</h3>');   $r->print('<h3>'.  &Apache::lonnet::domain($cdom,'description').'</h3>');
 }else{  }else{
  $r->print('\noindent{\large\textbf{'.$courseenv{'description'}.'}}\\\\\\\\\textbf{'.   $r->print('\noindent{\large\textbf{'.$courseenv{'description'}.'}}\\\\\\\\\textbf{'.
Line 268  if($target ne 'tex'){ Line 309  if($target ne 'tex'){
  if ($target ne 'tex') {   if ($target ne 'tex') {
     $r->print(&Apache::lonhtmlcommon::row_title($element));      $r->print(&Apache::lonhtmlcommon::row_title($element));
  } else {   } else {
     $r->print(' '.&Apache::lonxml::xmlparse($r,'tex',$element).' & ');       $r->print(' '.&Apache::lonxml::xmlparse($r,'tex',$element).' & ');
  }   }
         foreach (split(/\,/,$coursepersonnel{$element})) {          foreach (split(/\,/,$coursepersonnel{$element})) {
     my ($puname,$pudom)=split(/\:/,$_);      my ($puname,$pudom)=split(/\:/,$_);
Line 298  if($target ne 'tex'){ Line 339  if($target ne 'tex'){
     } else {      } else {
  $r->print('\end{tabular}\\\\');   $r->print('\end{tabular}\\\\');
     }      }
 #----------Print last update  
  my $lastmod=$syllabus{'uploaded.lastmodified'};  
        $lastmod=($lastmod?&Apache::lonlocal::locallocaltime($lastmod):&mt('never'));  
        my $who = &Apache::loncommon::aboutmewrapper(  
                     &Apache::loncommon::plainname($syllabus{'uploaded.name'},  
                      $syllabus{'uploaded.domain'}),$syllabus{'uploaded.name'},  
                      $syllabus{'uploaded.domain'});        
  if ($target ne 'tex') {  
    $r->print('<table><tr><td>'.&mt('Last updated').':</td><td>'.  
      $lastmod.'</td><td>'.  
      ($who ? &mt('by').' '.$who  
                            : '' ).  
      '</td></tr></table>');  
        } else {  
    $r->print('\\\\ '.&mt('Last updated').': '.$lastmod.' '.  
      ($who? &mt('by').'\\\\ '.  
             &Apache::loncommon::plainname($syllabus{'uploaded.name'},$syllabus{'uploaded.domain'})  
           :'')  
      .'\\\\');  
        }  
 #---------------------Print Extern URL Course Info  
 if( ($allowed) && ($target ne 'tex') ) {  
  my $protocol = $Apache::lonnet::protocol{$homeserver};  
   $protocol = 'http' if ($protocol ne 'https');  
  $r->print('<p>'.&mt('This syllabus can be publicly viewed at').' <tt>'.$protocol.'://'.&Apache::lonnet::hostname($homeserver).$r->uri.'</tt>'.&Apache::loncommon::help_open_topic('Syllabus_ExtLink').'</p>'.'<p>'.&mt('You can specify an external URL as Syllabus in the [_1].','<a href="/adm/parmset?action=crsenv">'.&mt('Course Parameters').'</a>').'</p>');  
 }  
 # -------------------------------------------------------------- Announcements?  # -------------------------------------------------------------- Announcements?
     my $day = &Apache::lonannounce::showday(time,2,      my $day = &Apache::lonannounce::showday(time,2,
  &Apache::lonannounce::readcalendar($cdom.'_'.$cnum));   &Apache::lonannounce::readcalendar($cdom.'_'.$cnum));
     if ($target ne 'tex') {      if ($target ne 'tex') {
  if($allowed){   if($allowed){
  &Apache::lontemplate::print_template($r,'RSS Feeds and Blogs',&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit),1,'LC_ContentBoxSpecial');   &Apache::lontemplate::print_start_template($r,'RSS Feeds and Blogs','LC_ContentBoxSpecial');
    $r->print(&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit));
    my $editurl= &Apache::lonnet::absolute_url().'/adm/'.$cdom.'/'.$cnum.'/_rss.html';
           $r->print( '<a href="'.$editurl.'">'.&mt('New RSS Feed or Blog').'</a>');
    &Apache::lontemplate::print_end_template($r);
  }   }
  elsif(&Apache::lonrss::advertisefeeds($cnum,$cdom) ne ''){   elsif(&Apache::lonrss::advertisefeeds($cnum,$cdom) ne ''){
  &Apache::lontemplate::print_template($r,'RSS Feeds and Blogs',&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit),1,'LC_ContentBoxSpecial');   &Apache::lontemplate::print_start_template($r,'RSS Feeds and Blogs','LC_ContentBoxSpecial');
    $r->print(&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit));
    &Apache::lontemplate::print_end_template($r);
  }   }
   
     } else {      } else {
  $r->print(&Apache::lonxml::xmlparse($r,'tex',$day));   $r->print(&Apache::lonxml::xmlparse($r,'tex',$day));
     }      }
 # ---------------------------------------------------------------- Get syllabus  # ---------------------------------------------------------------- Get syllabus
     if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {           if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {
        if ($allowed) {         if ($allowed) {
    $r->print('<form method="post">'.     $r->print('<form method="post">'.
      '<input type="hidden" name="forceedit" value="edit" />');       '<input type="hidden" name="forceedit" value="edit" />');
        }         }
        my @htmlids=();         my @htmlids=();
   
  foreach my $field (sort(keys(%syllabusfields))) {   foreach my $field (sort(keys(%syllabusfields))) {
    if (($syllabus{$field}=~/\w/) || ($allowed)) {     if (($syllabus{$field}=~/\w/) || ($allowed)) {
        my $message=$syllabus{$field};         my $message=$syllabus{$field};
        if ($field 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=~/\/$/)) {# make ssi call and remove everything but the body contents         if (($embstyle eq 'ssi') || ($curfext=~/\/$/)) {# 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') {# embed as an image         } elsif ($embstyle eq 'img') {# embed as an image
    $output='<img src="'.$filelink.'" />';     $output='<img src="'.$filelink.'" />';
        }         }
        if($output ne ''){         if($output ne ''){
        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{$field}.         $r->print('<h3>'.$syllabusfields{$field}.
  &Apache::loncommon::help_open_topic('Syllabus_URLs').'</h3>');   &Apache::loncommon::help_open_topic('Syllabus_URLs').'</h3>');
    } else {     } else {
        $r->print($message);         $r->print($message);
    }      }
        } else {         } else {
    &Apache::lonfeedback::newline_to_br(\$message);     &Apache::lonfeedback::newline_to_br(\$message);
    $message =~s|(https?\://[^\s]+)|<a href="$1"><tt>$1</tt></a>|g;     $message =~s|(https?\://[^\s]+)|<a href="$1"><tt>$1</tt></a>|g;
Line 386  if( ($allowed) && ($target ne 'tex') ) { Line 407  if( ($allowed) && ($target ne 'tex') ) {
    if ($target ne 'tex') {     if ($target ne 'tex') {
  if($allowed){   if($allowed){
  $r->print('<p>');   $r->print('<p>');
  }   }
  &Apache::lontemplate::print_template($r, $syllabusfields{$field}, $message,$allowed,'LC_ContentBoxSpecial');   &Apache::lontemplate::print_template($r, $syllabusfields{$field}, $message,$allowed,'LC_ContentBoxSpecial');
    } else {     } else {
        $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'.         $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'.
Line 399  if( ($allowed) && ($target ne 'tex') ) { Line 420  if( ($allowed) && ($target ne 'tex') ) {
  $r->print('</p>');   $r->print('</p>');
  &Apache::lontemplate::print_editbox_template($r, $syllabus{$field}, $field);   &Apache::lontemplate::print_editbox_template($r, $syllabus{$field}, $field);
  }   }
   
        }         }
    }     }
        }             }
   
        if ($allowed) {         if ($allowed) {
    $r->print('</form>'.     $r->print('</form>'.
      &Apache::lonhtmlcommon::htmlareaselectactive(@htmlids));       &Apache::lonhtmlcommon::htmlareaselectactive(@htmlids));
        }         }
       # if ($target ne 'tex') {$r->print('</p>');} else {$r->print('\\\\');}        # if ($target ne 'tex') {$r->print('</p>');} else {$r->print('\\\\');}
     } else {      } else {
  if ($target ne 'tex') {$r->print('<p>');} else {$r->print('\par ');}    if ($target ne 'tex') {$r->print('<p>');} else {$r->print('\par ');}
  $r->print(&mt('No syllabus information provided.'));   $r->print(&mt('No syllabus information provided.'));
  if ($target ne 'tex') {$r->print('</p>');}   if ($target ne 'tex') {$r->print('</p>');}
     }      }
     if ($target ne 'tex') {      if ($target ne 'tex') {
         if ($env{'form.backto'} eq 'coursecatalog') {          if ($env{'form.backto'} eq 'coursecatalog') {
             $r->print('<form name="backtocat" method="post" action="/adm/coursecatalog">'.              $r->print('<form name="backtocat" method="post" action="/adm/coursecatalog">'.
                       &Apache::lonhtmlcommon::echo_form_input(['backto','courseid']).                        &Apache::lonhtmlcommon::echo_form_input(['backto','courseid']).
Line 425  if( ($allowed) && ($target ne 'tex') ) { Line 446  if( ($allowed) && ($target ne 'tex') ) {
  $r->print('\end{document}');   $r->print('\end{document}');
     }      }
     return OK;      return OK;
 }   }
   
 1;  1;
 __END__  __END__

Removed from v.1.81  
changed lines
  Added in v.1.88


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