Diff for /loncom/interface/lonsyllabus.pm between versions 1.54 and 1.69.4.1

version 1.54, 2006/08/16 19:40:46 version 1.69.4.1, 2009/05/20 01:23:47
Line 66  sub handler { Line 66  sub handler {
   
 # ------------------------------------------------------------ Print the screen  # ------------------------------------------------------------ Print the screen
   
     my $rss_link =  
  &Apache::lonrss::rss_link('http://'.$ENV{'HTTP_HOST'}.'/public/'.$cdom.'/'.$cnum.'/Course_Announcements.rss');  
   
     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'}));
     }       } 
Line 112  sub handler { Line 109  sub handler {
                 
 # ----------------------------------------------------------------- Make header   # ----------------------------------------------------------------- Make header 
     if ($target ne 'tex') {      if ($target ne 'tex') {
    my $rss_link = &Apache::lonrss::rss_link($cnum,$cdom);
           my $js;
           if ($env{'form.backto'} eq 'coursecatalog') {
               $js .= <<"ENDSCRIPT";
   
   <script type="text/javascript">
   function ToCatalog(caller) {
       numidx = getIndexByName('coursenum');
       if (numidx > -1) {
           if (caller != 'details') {
               document.backtocat.elements[numidx].value = '';
           }
       }
       document.backtocat.submit();
   }
   
   function getIndexByName(item) {
       for (var i=0;i<document.backtocat.elements.length;i++) {
           if (document.backtocat.elements[i].name == item) {
               return i;
           }
       }
       return -1;
   }
   
   </script>
   
   ENDSCRIPT
           }
  my $start_page =    my $start_page = 
     &Apache::loncommon::start_page("Syllabus", $rss_link,      &Apache::loncommon::start_page("Syllabus", $rss_link.$js,
    {'function'       => $forcestudent,     {'function'       => $forcestudent,
     'domain'         => $cdom,      'domain'         => $cdom,
     'force_register' =>      'force_register' =>
  $env{'form.register'},});   $env{'form.register'},});
   
  $r->print($start_page.'<h1>'.$courseenv{'description'}.'</h1><h3>'.   $r->print($start_page);
                  $Apache::lonnet::domaindescription{$cdom}.'</h3>');          if ($env{'form.backto'} eq 'coursecatalog') {
               &Apache::lonhtmlcommon::clear_breadcrumbs();
               &Apache::lonhtmlcommon::add_breadcrumb
                ({href=>"javascript:ToCatalog()",
                  text=>"Course Catalog"});
               if ($env{'form.coursenum'} ne '') {
                   &Apache::lonhtmlcommon::add_breadcrumb
                     ({href=>"javascript:ToCatalog('details')",
                      text=>"Course details"});
               }
               &Apache::lonhtmlcommon::add_breadcrumb
                 ({href=>$r->uri,
                  text=>"Course syllabus"});
               $r->print(&Apache::lonhtmlcommon::breadcrumbs());
           }
           $r->print('<h1>'.$courseenv{'description'}.'</h1><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{'.
                  $Apache::lonnet::domaindescription{$cdom}.'}\\\\');    &Apache::lonnet::domain($cdom,'description').'}\\\\');
     }      }
 # -------------------------------------------------------------- Announcements?  # -------------------------------------------------------------- Announcements?
     my $day = &Apache::lonannounce::showday(time,2,      my $day = &Apache::lonannounce::showday(time,2,
Line 137  sub handler { Line 179  sub handler {
 # -------------------------------------------------------- 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') {
  $r->print('<table border="2">');   $r->print(&Apache::lonhtmlcommon::start_pick_box());
     } else {      } else {
  $r->print('\begin{tabular}{|p{0.45\textwidth}|p{0.45\textwidth}|}\hline');   $r->print('\begin{tabular}{|p{0.45\textwidth}|p{0.45\textwidth}|}\hline');
     }      }
     foreach my $element (sort keys %coursepersonnel) {      my @personnel=sort(keys(%coursepersonnel));
       my $lastpers=$personnel[$#personnel];
       foreach my $element (@personnel) {
  if ($target ne 'tex') {   if ($target ne 'tex') {
     $r->print('<tr><td>'.$element.'</td><td>');      $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(/\:/,$_);
     if ($target ne 'tex') {      if ($target ne 'tex') {
  $r->print(' '.&Apache::loncommon::aboutmewrapper(                  my $courseperson = &Apache::loncommon::plainname($puname,$pudom);
                               &Apache::loncommon::plainname($puname,                  if (($env{'user.name'} eq '') || ($env{'user.name'} eq 'public') ||
                               $pudom),$puname,$pudom));                      ($env{'user.domain'} eq '') || ($env{'user.domain'} eq 'public')) {
       $r->print(' '.$courseperson);
                   } else {
                       $r->print(' '.&Apache::loncommon::aboutmewrapper($courseperson,
                                 $puname,$pudom));
                   }
     } else {      } else {
  $r->print(' '.&Apache::loncommon::plainname($puname,   $r->print(' '.&Apache::loncommon::plainname($puname,
                               $pudom).' ');                                $pudom).' ');
     }      }
  }   }
  if ($target ne 'tex') {   if ($target ne 'tex') {
     $r->print('</td></tr>');              my $lastclose=$element eq $lastpers?1:0;
               $r->print(&Apache::lonhtmlcommon::row_closure($lastclose));
  } else {   } else {
     $r->print('\\\\ \hline');      $r->print('\\\\ \hline');
  }   }
     }      }
     if ($target ne 'tex') {      if ($target ne 'tex') {
  $r->print('</table>');   $r->print(&Apache::lonhtmlcommon::end_pick_box());
     } else {      } else {
  $r->print('\end{tabular}\\\\');   $r->print('\end{tabular}\\\\');
     }      }
Line 189  sub handler { Line 239  sub handler {
           if ($forcestudent or $target eq 'tex') { $allowed=0; }            if ($forcestudent or $target eq 'tex') { $allowed=0; }
        }         }
        if ($allowed) {         if ($allowed) {
             my $protocol = $Apache::lonnet::protocol{$homeserver};
             $protocol = 'http' if ($protocol ne 'https');
           $r->print('<p>'.            $r->print('<p>'.
 &Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes','Help with filling in text boxes').'</p><p>'.&mt('This syllabus can be publicly viewed at')  &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>http://'.      .' <tt>'.$protocol.'://'.
     $Apache::lonnet::hostname{$homeserver}.$r->uri.'</tt>'.      &Apache::lonnet::hostname($homeserver).$r->uri.'</tt>'.
                &Apache::loncommon::help_open_topic('Syllabus_ExtLink').'</p>'.                 &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>'.            '<p>'.&mt('You can specify an external URL as Syllabus in the [_1].','<a href="/adm/parmset?action=crsenv">'.&mt('Course Parameters').'</a>').'</p>'.
   '<p><a href="'.$r->uri.'?forcestudent=1"><font size="+1">'.    '<p><a href="'.$r->uri.'?forcestudent=1"><font size="+1">'.
Line 206  sub handler { Line 258  sub handler {
   }    }
       }        }
        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|^https?\://([^/]+)/(.+)$|) {
     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) {    my $hostname = &Apache::lonnet::hostname($host);
                               if ($1=~/$Apache::lonnet::hostname{$_}/i) {    my %all_hostnames = &Apache::lonnet::all_hostnames();
             foreach my $possible_host (keys(%all_hostnames)) {
                                 if ($possible_host =~ /\Q$hostname\E/i) {
          $url=$remainder;           $url=$remainder;
       }        }
           }            }
       }        }
 # norm internal URLs  # norm internal URLs
                       unless ($url=~/^http\:/) {                        unless ($url=~/^https?\:/) {
           $url=&Apache::lonnet::clutter($url);            $url=&Apache::lonnet::clutter($url);
                       }                        }
 # re-assemble field  # re-assemble field
Line 239  sub handler { Line 294  sub handler {
           $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 258  sub handler { Line 313  sub handler {
                      $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('<table><tr><td>'.&mt('Last updated').':</td><td>'.
      $lastmod.'</td><td>'.&mt('by').' '.$who.       $lastmod.'</td><td>'.
        ($who ? &mt('by').' '.$who
                              : '' ).
      '</td></tr></table><p>');       '</td></tr></table><p>');
        } else {         } else {
    $r->print('\\\\ '.&mt('Last updated').': '.$lastmod.' '.&mt('by').'\\\\ '.     $r->print('\\\\ '.&mt('Last updated').': '.$lastmod.' '.
      &Apache::loncommon::plainname($syllabus{'uploaded.name'},       ($who? &mt('by').'\\\\ '.
                      $syllabus{'uploaded.domain'}).'\\\\');              &Apache::loncommon::plainname($syllabus{'uploaded.name'},$syllabus{'uploaded.domain'})
             :'')
        .'\\\\');
        }         }
        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 (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="'.&mt('Save').'" />');
    &HTML::Entities::encode($syllabus{$_},'"&<>').         }
            '</textarea> <input type="submit" name="storesyl" value="Store" />');     }
       }  
   }  
        }         }
        if ($allowed) {         if ($allowed) {
    $r->print('</form>'.     $r->print('</form>'.
Line 334  sub handler { Line 391  sub handler {
        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('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') {
               $r->print('<form name="backtocat" method="post" action="/adm/coursecatalog">'.
                         &Apache::lonhtmlcommon::echo_form_input(['backto','courseid']).
                         '</form>');
           }
  $r->print(&Apache::loncommon::end_page());   $r->print(&Apache::loncommon::end_page());
     } else {      } else {
  $r->print('\end{document}');   $r->print('\end{document}');

Removed from v.1.54  
changed lines
  Added in v.1.69.4.1


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