Diff for /loncom/interface/lonsyllabus.pm between versions 1.78 and 1.89

version 1.78, 2009/02/19 18:55:53 version 1.89, 2009/05/11 13:34:10
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 162  ENDSCRIPT Line 162  ENDSCRIPT
                text=>"Course syllabus"});                 text=>"Course syllabus"});
             $r->print(&Apache::lonhtmlcommon::breadcrumbs());              $r->print(&Apache::lonhtmlcommon::breadcrumbs());
         }          }
         $r->print('<h1>'.$courseenv{'description'}.'</h1><h3>'.  
   &Apache::lonnet::domain($cdom,'description').'</h3>');  
     } else {  
  $r->print('\noindent{\large\textbf{'.$courseenv{'description'}.'}}\\\\\\\\\textbf{'.  
   &Apache::lonnet::domain($cdom,'description').'}\\\\');  
     }  
 # -------------------------------------------------------- Get course personnel  
     my %coursepersonnel=&Apache::lonnet::get_course_adv_roles($cdom.'/'.$cnum);  
     if ($target ne 'tex') {  
  $r->print(&Apache::lonhtmlcommon::start_pick_box());  
     } else {  
  $r->print('\begin{tabular}{|p{0.45\textwidth}|p{0.45\textwidth}|}\hline');  
     }  
     my @personnel=sort(keys(%coursepersonnel));  
     my $lastpers=$personnel[$#personnel];  
     foreach my $element (@personnel) {  
  if ($target ne 'tex') {  
     $r->print(&Apache::lonhtmlcommon::row_title($element));  
  } else {  
     $r->print(' '.&Apache::lonxml::xmlparse($r,'tex',$element).' & ');   
  }  
         foreach (split(/\,/,$coursepersonnel{$element})) {  
     my ($puname,$pudom)=split(/\:/,$_);  
     if ($target ne 'tex') {  
                 my $courseperson = &Apache::loncommon::plainname($puname,$pudom);  
                 if (($env{'user.name'} eq '') || ($env{'user.name'} eq 'public') ||  
                     ($env{'user.domain'} eq '') || ($env{'user.domain'} eq 'public')) {  
     $r->print(' '.$courseperson);  
                 } else {  
                     $r->print(' '.&Apache::loncommon::aboutmewrapper($courseperson,  
                               $puname,$pudom));  
                 }  
     } else {  
  $r->print(' '.&Apache::loncommon::plainname($puname,  
                               $pudom).' ');  
     }  
  }  
  if ($target ne 'tex') {  
             my $lastclose=$element eq $lastpers?1:0;  
             $r->print(&Apache::lonhtmlcommon::row_closure($lastclose));  
  } else {  
     $r->print('\\\\ \hline');  
  }  
     }  
     if ($target ne 'tex') {  
  $r->print(&Apache::lonhtmlcommon::end_pick_box());  
     } else {  
  $r->print('\end{tabular}\\\\');  
     }  
 # -------------------------------------------------------------- Announcements?  
     my $day = &Apache::lonannounce::showday(time,2,  
  &Apache::lonannounce::readcalendar($cdom.'_'.$cnum));  
     if ($target ne 'tex') {  
  &Apache::lontemplate::print_template($r,'RSS Feeds and Blogs',&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit),1,'LC_ContentBoxSpecial');  
     } else {  
  $r->print(&Apache::lonxml::xmlparse($r,'tex',$day));  
     }      }
 # ---------------------------------------------------------- Load syllabus info  # ---------------------------------------------------------- Load syllabus info
     my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum);      my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum);
Line 238  ENDSCRIPT Line 183  ENDSCRIPT
   }    }
           if ($forcestudent or $target eq 'tex') { $allowed=0; }            if ($forcestudent or $target eq 'tex') { $allowed=0; }
        }         }
        if ($allowed) {  
           my $protocol = $Apache::lonnet::protocol{$homeserver};  
           $protocol = 'http' if ($protocol ne 'https');  
           $r->print('<p>'.&Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')).'</p><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>');  
       }   
        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 293  ENDSCRIPT Line 229  ENDSCRIPT
            &Apache::lonnet::put('syllabus',\%syllabus,$cdom,$cnum);             &Apache::lonnet::put('syllabus',\%syllabus,$cdom,$cnum);
        }         }
     }      }
 # ---------------------------------------------------------------- Get syllabus  
     if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) {  #---------------------Print External URL Syllabus Info
        my $lastmod=$syllabus{'uploaded.lastmodified'};  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 ($allowed) {
    $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'));         $lastmod=($lastmod?&Apache::lonlocal::locallocaltime($lastmod):&mt('never'));
        my $who = &Apache::loncommon::aboutmewrapper(         my $who = &Apache::loncommon::aboutmewrapper(
                     &Apache::loncommon::plainname($syllabus{'uploaded.name'},                      &Apache::loncommon::plainname($syllabus{'uploaded.name'},
                      $syllabus{'uploaded.domain'}),$syllabus{'uploaded.name'},                       $syllabus{'uploaded.domain'}),$syllabus{'uploaded.name'},
                      $syllabus{'uploaded.domain'});                       $syllabus{'uploaded.domain'});
        if ($target ne 'tex') {   if ($target ne 'tex') {
    $r->print('<table><tr><td>'.&mt('Last updated').':</td><td>'.     $r->print('<div class="LC_info">'.&mt('Last updated').': '.
      $lastmod.'</td><td>'.       $lastmod . ' '.
      ($who ? &mt('by').' '.$who       ($who ? &mt('by').' '.$who
                            : '' ).                             : '' ) .
      '</td></tr></table><p>');               '</div>' );
   
        } else {         } else {
    $r->print('\\\\ '.&mt('Last updated').': '.$lastmod.' '.     $r->print('\\\\ '.&mt('Last updated').': '.$lastmod.' '.
      ($who? &mt('by').'\\\\ '.       ($who? &mt('by').'\\\\ '.
Line 314  ENDSCRIPT Line 273  ENDSCRIPT
           :'')            :'')
      .'\\\\');       .'\\\\');
        }         }
        #--------Functions
  if ($target ne 'tex') {  if ($target ne 'tex') {
  &Apache::lontemplate::print_start_page_functions($r);   if( $allowed || $privileged) {
  if($allowed){                  $r->print(&Apache::lontemplate::start_functionslist());
  &Apache::lontemplate::print_functions_content($r,'<a href="'.$r->uri.'?forcestudent=1">'.&mt('Show Public View').'</a>'.   if ($allowed) {
           &Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView'));                            $r->print(&Apache::lontemplate::item_functionslist(
  }elsif($privileged){                          '<a href="'.$r->uri.'?forcestudent=1">'.&mt('Show Public View').'</a>'
  &Apache::lontemplate::print_functions_content($r,'<a href="'.$r->uri.'?forceedit=1">'.&mt('Edit').'</a>');                          .&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView')));
    } elsif ($privileged) {
                       $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
   if ($target ne 'tex') {
    $r->print('<h1>'.$courseenv{'description'}.'</h1>');
    $r->print('<h3>'.  &Apache::lonnet::domain($cdom,'description').'</h3>');
   } else {
    $r->print('\noindent{\large\textbf{'.$courseenv{'description'}.'}}\\\\\\\\\textbf{'.
    &Apache::lonnet::domain($cdom,'description').'}\\\\');
   }
   # -------------------------------------------------------- Get course personnel
       my %coursepersonnel=&Apache::lonnet::get_course_adv_roles($cdom.'/'.$cnum);
       if ($target ne 'tex') {
    $r->print(&Apache::lonhtmlcommon::start_pick_box());
       } else {
    $r->print('\begin{tabular}{|p{0.45\textwidth}|p{0.45\textwidth}|}\hline');
       }
       my @personnel=sort(keys(%coursepersonnel));
       my $lastpers=$personnel[$#personnel];
       foreach my $element (@personnel) {
    if ($target ne 'tex') {
       $r->print(&Apache::lonhtmlcommon::row_title($element));
    } else {
       $r->print(' '.&Apache::lonxml::xmlparse($r,'tex',$element).' & ');
    }
           foreach (split(/\,/,$coursepersonnel{$element})) {
       my ($puname,$pudom)=split(/\:/,$_);
       if ($target ne 'tex') {
                   my $courseperson = &Apache::loncommon::plainname($puname,$pudom);
                   if (($env{'user.name'} eq '') || ($env{'user.name'} eq 'public') ||
                       ($env{'user.domain'} eq '') || ($env{'user.domain'} eq 'public')) {
       $r->print(' '.$courseperson);
                   } else {
                       $r->print(' '.&Apache::loncommon::aboutmewrapper($courseperson,
                                 $puname,$pudom));
                   }
       } else {
    $r->print(' '.&Apache::loncommon::plainname($puname,
                                 $pudom).' ');
       }
    }
    if ($target ne 'tex') {
               my $lastclose=$element eq $lastpers?1:0;
               $r->print(&Apache::lonhtmlcommon::row_closure($lastclose));
    } else {
       $r->print('\\\\ \hline');
    }
       }
       if ($target ne 'tex') {
    $r->print(&Apache::lonhtmlcommon::end_pick_box());
       } else {
    $r->print('\end{tabular}\\\\');
       }
   # -------------------------------------------------------------- Announcements?
       my $day = &Apache::lonannounce::showday(time,2,
    &Apache::lonannounce::readcalendar($cdom.'_'.$cnum));
       if ($target ne 'tex') {
    if ($allowed) {
    &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 '') {
    &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 {
    $r->print(&Apache::lonxml::xmlparse($r,'tex',$day));
       }
   # ---------------------------------------------------------------- Get syllabus
       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};
Line 340  ENDSCRIPT Line 374  ENDSCRIPT
    $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 ($output ne '') {
    $message.='<p>'.$output.'</p>';         if ($target ne 'tex') {
        } else {     $message.='<p>'.$output.'</p>';
    $message.=' '.&Apache::lonxml::xmlparse($r,'tex','<p>'.$output.'</p>').' ';         } else {
        }           $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 370  ENDSCRIPT Line 404  ENDSCRIPT
    }     }
    $message=&Apache::lontexconvert::msgtexconverted($message);     $message=&Apache::lontexconvert::msgtexconverted($message);
    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 381  ENDSCRIPT Line 415  ENDSCRIPT
    push(@htmlids,$field);     push(@htmlids,$field);
        }         }
        if ($allowed) {         if ($allowed) {
  if($target ne 'tex'){   if ($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>');}
     }      }
Line 410  ENDSCRIPT Line 445  ENDSCRIPT
  $r->print('\end{document}');   $r->print('\end{document}');
     }      }
     return OK;      return OK;
 }   }
   
 1;  1;
 __END__  __END__

Removed from v.1.78  
changed lines
  Added in v.1.89


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