Diff for /loncom/interface/lonsyllabus.pm between versions 1.90 and 1.113

version 1.90, 2009/05/15 13:43:46 version 1.113, 2012/11/08 21:33:10
Line 52  sub handler { Line 52  sub handler {
     my (undef,undef,$cdom,$cnum)=split(/\//,$r->uri);      my (undef,undef,$cdom,$cnum)=split(/\//,$r->uri);
 # ------------------------------------------------------------ Get query string  # ------------------------------------------------------------ Get query string
     &Apache::loncommon::get_unprocessed_cgi      &Apache::loncommon::get_unprocessed_cgi
                         ($ENV{'QUERY_STRING'},['forcestudent','register','forceedit','wrapperdisplay']);                          ($ENV{'QUERY_STRING'},['register','forceedit']);
 # ----------------------------------------------------- Is this even a course?  # ----------------------------------------------------- Is this even a course?
     my $homeserver=&Apache::lonnet::homeserver($cnum,$cdom);      my $homeserver=&Apache::lonnet::homeserver($cnum,$cdom);
     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;
       &Apache::loncommon::simple_error_page($r,'No syllabus available',          &Apache::loncommon::simple_error_page($r,'No syllabus available',
       'No syllabus available');                            'No syllabus available');
           return OK;
       } elsif (!&Apache::lonnet::is_course($cdom,$cnum)) {
           &Apache::loncommon::content_type($r,'text/html');
           $r->send_http_header;
           &Apache::loncommon::simple_error_page($r,'No syllabus available',
                             'The course/community for which the syllabus was requested does not exist.');
         return OK;          return OK;
     }      }
 # ------------------------------------- There is such a course, get environment  # ------------------------------------- There is such a course, get environment
Line 68  sub handler { Line 74  sub handler {
 # ------------------------------------------------------------ Print the screen  # ------------------------------------------------------------ Print the screen
   
     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/) {
           $r->print( Apache::lonwrapper::wrapper($externalsyllabus) );
        if ($env{'form.wrapperdisplay'} eq 'menu') {          return OK;
        $r->print(&Apache::lonwrapper::simple_menu());  
        } else {  
        $r->print(&Apache::lonwrapper::wrapper("/public/$cdom/$cnum/syllabus?wrapperdisplay=menu",  
    $externalsyllabus));  
        }  
        return OK;  
     }      }
   
 # ------------------------------ The buck stops here: internal syllabus display  # ------------------------------ The buck stops here: internal syllabus display
Line 103  sub handler { Line 103  sub handler {
        'kkk_textbook'       => 'Textbook',         'kkk_textbook'       => 'Textbook',
        'lll_includeurl'     => 'URLs To Include in Syllabus');         'lll_includeurl'     => 'URLs To Include in Syllabus');
 # --------------------------------------------------------------- Force Student  # --------------------------------------------------------------- Force Student
     my $forcestudent='';      my ($forceedit,$forcestudent);
     if ($env{'form.forcestudent'}) { $forcestudent='student'; };      if ($env{'form.forceedit'}) { $forceedit=1; }
     my $forceedit='';      if (!$forceedit) {
     if ($env{'form.forceedit'}) { $forceedit='edit'; }          $forcestudent=1;
       }
 # ----------------------------------------------------------------- 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;
         if ($env{'form.backto'} eq 'coursecatalog') {          if ($env{'form.backto'} eq 'coursecatalog') {
             $js .= <<"ENDSCRIPT";              $js .= <<"ENDSCRIPT";
Line 139  function getIndexByName(item) { Line 139  function getIndexByName(item) {
   
 ENDSCRIPT  ENDSCRIPT
         }          }
     my $start_page =          my $forcereg;
      &Apache::loncommon::start_page("Syllabus", $rss_link.$js,          if ($env{'form.register'}) {
    {'function'       => $forcestudent,              $forcereg = 1;
     'domain'         => $cdom,          }
     'force_register' =>          my $brcrum = [];
  $env{'form.register'},});  
   
     $r->print($start_page);  
         if ($env{'form.backto'} eq 'coursecatalog') {          if ($env{'form.backto'} eq 'coursecatalog') {
             &Apache::lonhtmlcommon::clear_breadcrumbs();              &Apache::lonhtmlcommon::clear_breadcrumbs();
             &Apache::lonhtmlcommon::add_breadcrumb              $brcrum = [{href=>"javascript:ToCatalog();",
                 ({href=>"javascript:ToCatalog()",                          text=>&mt('Course/Community Catalog'),
                 text=>"Course Catalog"});                          no_mt=>1}
                         ];
             if ($env{'form.coursenum'} ne '') {              if ($env{'form.coursenum'} ne '') {
                 &Apache::lonhtmlcommon::add_breadcrumb                  push(@{$brcrum},
                     ({href=>"javascript:ToCatalog('details')",                        {href=>"javascript:ToCatalog('details')",
                     text=>"Course details"});                         text=>"Course details"});
             }              }
             &Apache::lonhtmlcommon::add_breadcrumb              push(@{$brcrum},
                 ({href=>$r->uri,                    {href=>$r->uri,
                 text=>"Course syllabus"});                     text=>"Course syllabus"});
             $r->print(&Apache::lonhtmlcommon::breadcrumbs());          }   
         }          my $start_page =
            &Apache::loncommon::start_page("Syllabus", $rss_link.$js,
                          {'function'       => undef,
                           'domain'         => $cdom,
                           'force_register' => $forcereg,
                           'bread_crumbs'   => $brcrum,
                          });
   
           $r->print($start_page);
     }      }
 # ---------------------------------------------------------- Load syllabus info  # ---------------------------------------------------------- Load syllabus info
     my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum);      my %syllabus=&Apache::lonnet::dump('syllabus',$cdom,$cnum);
     my $allowed=0;      my $allowed=0;
     my $privileged=0;  
   
 # This handler might be called anonymously ...  # This handler might be called anonymously ...
 # ----------------------------------------------------- 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'}          && $cdom eq $env{'course.'.$env{'request.course.id'}.'.domain'}
     && $cnum eq $env{'course.'.$env{'request.course.id'}.'.num'}) {          && $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;  
         if (($syllabus{'uploaded.lastmodified'}) && (!$forceedit)) {  
             $forcestudent='student';  
         }  
             if ($forcestudent or $target eq 'tex') { $allowed=0; }              if ($forcestudent or $target eq 'tex') { $allowed=0; }
         }          }
   #store what the user typed in
         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};
             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{$syl_field}=$field;   #here it will be stored
                   $syllabus{$syl_field}=$field;
                 if ($syl_field eq 'lll_includeurl') { # clean up included URLs                  if ($syl_field eq 'lll_includeurl') { # clean up included URLs
                     my $field='';                      my $field='';
                 foreach my $value (split(/\n/,$syllabus{$syl_field})) {                      foreach my $value (split(/\n/,$syllabus{$syl_field})) {
                 my $url=$value;                          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=~m|^https?\://([^/]+)/(.+)$|) {                          if ($url=~m|^https?\://([^/]+)/(.+)$|) {
                 my $host = $1;                              my $host = $1;
                             my $remainder=$2;                              my $remainder=$2;
 # remove the hostname from internal URLs  # remove the hostname from internal URLs
                 my $hostname = &Apache::lonnet::hostname($host);                              my $hostname = &Apache::lonnet::hostname($host);
                 my %all_hostnames = &Apache::lonnet::all_hostnames();                              my %all_hostnames = &Apache::lonnet::all_hostnames();
                     foreach my $possible_host (keys(%all_hostnames)) {                              foreach my $possible_host (keys(%all_hostnames)) {
                                 if ($possible_host =~ /\Q$hostname\E/i) {                                  if ($possible_host =~ /\Q$hostname\E/i) {
                         $url=$remainder;                                      $url=$remainder;
                     }                                  }
                     }                              }
                 }                          }
 # norm internal URLs  # norm internal URLs
                         unless ($url=~/^https?\:/) {                          unless ($url=~/^https?\:/) {
                     $url=&Apache::lonnet::clutter($url);                              $url=&Apache::lonnet::clutter($url);
                         }                          }
 # re-assemble field  # re-assemble field
                         if ($url) {                          if ($url) {
                     $field.=$url."\n";                              $field.=$url."\n";
                         }                          }
             }                      }
                     $syllabus{$syl_field}=$field;                      $syllabus{$syl_field}=$field;
             }                  }
             }              }
             $syllabus{'uploaded.domain'}=$env{'user.domain'};              $syllabus{'uploaded.domain'}=$env{'user.domain'};
             $syllabus{'uploaded.name'}=$env{'user.name'};              $syllabus{'uploaded.name'}=$env{'user.name'};
Line 230  ENDSCRIPT Line 232  ENDSCRIPT
         }          }
     }      }
   
 #---------------------Print External URL Syllabus Info      if ($allowed) {
     if( ($allowed) && ($target ne 'tex') ) {  #---------------------------------- Print External URL Syllabus Info if editing
     my $protocol = $Apache::lonnet::protocol{$homeserver};          if ($target ne 'tex') {
      $protocol = 'http' if ($protocol ne 'https');              my $protocol = $Apache::lonnet::protocol{$homeserver};
         $r->print('<p class="LC_info">'              $protocol = 'http' if ($protocol ne 'https');
                  .&mt('This syllabus can be publicly viewed at [_1]'              $r->print('<div class="LC_info">'
                      ,'<tt>'.$protocol.'://'.&Apache::lonnet::hostname($homeserver).$r->uri.'</tt>')                       .'<p>'
                  .'&nbsp;'.&Apache::loncommon::help_open_topic('Syllabus_ExtLink')                       .&mt('This syllabus can be publicly viewed at [_1]'
                  .'</p>'                            ,'<tt>'.$protocol.'://'.&Apache::lonnet::hostname($homeserver).$r->uri.'</tt>')
                  .'<p class="LC_info">'                       .'&nbsp;'.&Apache::loncommon::help_open_topic('Syllabus_ExtLink')
                  .&mt('Instead of using this template you can specify an external URL as Syllabus in the [_1]Course Parameters[_2].'                       .'</p>'
                      ,'<a href="/adm/parmset?action=crsenv">','</a>')                       .'<p>'
                  .'</p>'                       .&mt('Instead of using this template you can specify an external URL as Syllabus in the [_1]Course Configuration[_2].'
         );                            ,'<a href="/adm/courseprefs?actions=courseinfo&amp;phase=display">','</a>')
     }                       .'</p>'
                        .'</div>');
 #-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'));  
     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 {      } else {
     $r->print('\\\\ '.&mt('Last updated').': '.$lastmod.' '.  #--------------------------------------------- Print last update unless editing
     ($who? &mt('by').'\\\\ '.          my $lastmod=$syllabus{'uploaded.lastmodified'};
             &Apache::loncommon::plainname($syllabus{'uploaded.name'},$syllabus{'uploaded.domain'})          $lastmod=($lastmod?&Apache::lonlocal::locallocaltime($lastmod):&mt('never'));
           :'')          my $who;
      .'\\\\');          if ($syllabus{'uploaded.lastmodified'}) {
     }              if (($env{'user.name'} ne 'public') && ($env{'user.domain'} ne 'public')) {
 #--------Functions                  $who = &Apache::loncommon::aboutmewrapper(
     if ($target ne 'tex') {                         &Apache::loncommon::plainname($syllabus{'uploaded.name'},
     if( $allowed || $privileged) {                         $syllabus{'uploaded.domain'}),$syllabus{'uploaded.name'},
             $r->print(&Apache::lontemplate::start_functionslist());                         $syllabus{'uploaded.domain'});
  if ($allowed) {              } else {
             $r->print(&Apache::lontemplate::item_functionslist(  # Public user?
                         '<a href="'.$r->uri.'?forcestudent=1">'.&mt('Show Public View').'</a>'  # Only display name of user, but no link to personal information page
                        .&Apache::loncommon::help_open_topic('Uploaded_Templates_PublicView')));                  $who = &Apache::loncommon::plainname(
  } elsif ($privileged) {                             $syllabus{'uploaded.name'},
             $r->print(&Apache::lontemplate::item_functionslist(                             $syllabus{'uploaded.domain'});
                         '<a href="'.$r->uri.'?forceedit=1">'.&mt('Edit').'</a>'));              }
  }          }
             $r->print(&Apache::lontemplate::end_functionslist());          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'})
                        :'')
                       .'\\\\');
           }
     }      }
 #----------------------------Print Headtitle  
   #-------------------------------------------------------------- Print Headtitle
     if ($target ne 'tex') {      if ($target ne 'tex') {
     $r->print('<h1>'.$courseenv{'description'}.'</h1>');          $r->print('<div class="LC_Box">'.
     $r->print('<h3>'.  &Apache::lonnet::domain($cdom,'description').'</h3>');                     '<h2 class="LC_hcell">'.$courseenv{'description'}.'</h2>');
           if ($allowed) {
                $r->print('<div style="margin: 0; float:left;">'.
                          '<h3>'.&Apache::lonnet::domain($cdom,'description').'</h3>'.
                          '</div>');
   # Print Help Text if editing at right side of screen
                $r->print('<div style="margin: 0; float:right;">'.
                          &Apache::loncommon::help_open_topic('Uploaded_Templates_TextBoxes',&mt('Help with filling in text boxes')).
                          '</div><br clear="all" />');
           } else {
               $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{'.
     &Apache::lonnet::domain($cdom,'description').'}\\\\');          &Apache::lonnet::domain($cdom,'description').'}\\\\');
     }      }
 # -------------------------------------------------------- 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(&Apache::lonhtmlcommon::start_pick_box());          $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');
     }      }
     my @personnel=sort(keys(%coursepersonnel));      my @personnel=sort(keys(%coursepersonnel));
     my $lastpers=$personnel[$#personnel];      my $lastpers=$personnel[$#personnel];
     foreach my $element (@personnel) {      foreach my $element (@personnel) {
     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).' & ');
     }          }
           my @coursepersonlist;
         foreach (split(/\,/,$coursepersonnel{$element})) {          foreach (split(/\,/,$coursepersonnel{$element})) {
         my ($puname,$pudom)=split(/\:/,$_);              my ($puname,$pudom)=split(/\:/,$_);
         if ($target ne 'tex') {              if ($target ne 'tex') {
                 my $courseperson = &Apache::loncommon::plainname($puname,$pudom);                  my $courseperson = &Apache::loncommon::plainname($puname,$pudom);
                 if (($env{'user.name'} eq '') || ($env{'user.name'} eq 'public') ||                  if (($env{'user.name'} eq '') || ($env{'user.name'} eq 'public') ||
                     ($env{'user.domain'} eq '') || ($env{'user.domain'} eq 'public')) {                      ($env{'user.domain'} eq '') || ($env{'user.domain'} eq 'public')) {
             $r->print(' '.$courseperson);                      push(@coursepersonlist,$courseperson);
                 } else {                  } else {
                     $r->print(' '.&Apache::loncommon::aboutmewrapper($courseperson,                      push(@coursepersonlist,&Apache::loncommon::aboutmewrapper($courseperson,
                               $puname,$pudom));                                $puname,$pudom));
                 }                  }
         } else {              } else {
         $r->print(' '.&Apache::loncommon::plainname($puname,                  push(@coursepersonlist,&Apache::loncommon::plainname($puname,
                               $pudom).' ');                                $pudom).' ');
         }              }
     }          }
     if ($target ne 'tex') {          $r->print(join(", ",@coursepersonlist));
           if ($target ne 'tex') {
             my $lastclose=$element eq $lastpers?1:0;              my $lastclose=$element eq $lastpers?1:0;
             $r->print(&Apache::lonhtmlcommon::row_closure($lastclose));              $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(&Apache::lonhtmlcommon::end_pick_box());          $r->print(&Apache::lonhtmlcommon::end_pick_box());
     } else {      } else {
     $r->print('\end{tabular}\\\\');          $r->print('\end{tabular}\\\\');
     }      }
 # -------------------------------------------------------------- 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_start_template($r,'RSS Feeds and Blogs','LC_ContentBoxSpecial');              &Apache::lontemplate::print_start_template($r,&mt('RSS Feeds and Blogs'),'LC_Box');
     $r->print(&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit));              $r->print(&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit));
     my $editurl= &Apache::lonnet::absolute_url().'/adm/'.$cdom.'/'.$cnum.'/_rss.html';              my $editurl= &Apache::lonnet::absolute_url().'/adm/'.$cdom.'/'.$cnum.'/_rss.html';
         $r->print( '<a href="'.$editurl.'">'.&mt('New RSS Feed or Blog').'</a>');              $r->print( '<a href="'.$editurl.'">'.&mt('New RSS Feed or Blog').'</a>');
     &Apache::lontemplate::print_end_template($r);              &Apache::lontemplate::print_end_template($r);
     } elsif (&Apache::lonrss::advertisefeeds($cnum,$cdom) ne '') {          } elsif (&Apache::lonrss::advertisefeeds($cnum,$cdom) ne '') {
     &Apache::lontemplate::print_start_template($r,'RSS Feeds and Blogs','LC_ContentBoxSpecial');              &Apache::lontemplate::print_start_template($r,&mt('RSS Feeds and Blogs'),'LC_Box');
     $r->print(&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit));              $r->print(&Apache::lonrss::advertisefeeds($cnum,$cdom,$forceedit));
     &Apache::lontemplate::print_end_template($r);              &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" action="">'.
         '<input type="hidden" name="forceedit" value="edit" />');              '<input type="hidden" name="forceedit" value="'.$env{'form.forceedit'}.'" />');
         }  
         my @htmlids=();  
   
     foreach my $field (sort(keys(%syllabusfields))) {  
         if (($syllabus{$field}=~/\w/) || ($allowed)) {  
             my $message=$syllabus{$field};  
             if ($field eq 'lll_includeurl') { # this is the "included" field  
             my $urls=$message;  
             $message='';  
             foreach my $filelink (split(/\n/,$urls)) {  
                 my $output='';  
            # embed style?  
                 my ($curfext)=($filelink=~/\.([^\.]+)$/);  
                 my $embstyle=&Apache::loncommon::fileembstyle($curfext);  
                 if (($embstyle eq 'ssi') || ($curfext=~/\/$/)) {# make ssi call and remove everything but the body contents  
                 $output=&Apache::lonnet::ssi_body($filelink);  
                 } elsif ($embstyle eq 'img') {# embed as an image  
                 $output='<img src="'.$filelink.'" />';  
                 }  
                 if ($output ne '') {  
               if ($target ne 'tex') {  
               $message.='<p>'.$output.'</p>';  
               } else {  
               $message.=' '.&Apache::lonxml::xmlparse($r,'tex','<p>'.$output.'</p>').' ';  
               }  
             }  
             }  
             if ($allowed) {  
                 $r->print('<h3>'.$syllabusfields{$field}.  
             &Apache::loncommon::help_open_topic('Syllabus_URLs').'</h3>');  
             } else {  
                 $r->print($message);  
             }  
             } else {  
             &Apache::lonfeedback::newline_to_br(\$message);  
             $message =~s|(https?\://[^\s]+)|<a href="$1"><tt>$1</tt></a>|g;  
             if ($allowed) {  
                 $message=&Apache::lonspeller::markeduptext($message);  
             }  
             $message=&Apache::lontexconvert::msgtexconverted($message);  
             if ($target ne 'tex') {  
             if ($allowed) {  
             $r->print('<p>');  
             }  
             &Apache::lontemplate::print_template($r, $syllabusfields{$field}, $message,$allowed,'LC_ContentBoxSpecial');  
             } else {  
                 $r->print('\\\\\textbf{'.$syllabusfields{$field}.'}\\\\'.  
         &Apache::lonxml::xmlparse($r,'tex',$message).'\\\\');  
             }  
             push(@htmlids,$field);  
             }  
             if ($allowed) {  
         if ($target ne 'tex') {  
         $r->print('</p>');  
         &Apache::lontemplate::print_editbox_template($r, $syllabus{$field}, $field);  
         }  
             }  
         }  
         }          }
    my $url_include_handler = sub {
    my ($r, $field, $message, $group, $data_ref, $fields_ref, $target, $allowed) = @_;
    my %data = %{$data_ref};
    my %fields = %{$fields_ref};
    my $urls=$message;
    $message='';
    foreach my $filelink (split(/\n/,$urls)) {
    my $output='';
      # embed style?
    my ($curfext)=($filelink=~/\.([^\.]+)$/);
    my $embstyle=&Apache::loncommon::fileembstyle($curfext);
    if (($embstyle eq 'ssi') || ($curfext=~/\/$/)) {# make ssi call and remove everything but the body contents
    $output=&Apache::lonnet::ssi_body($filelink);
    } elsif ($embstyle eq 'img') {# embed as an image
    $output='<img src="'.$filelink.'" />';
    }
    if ($output ne '') {
      if ($target ne 'tex') {
      $message.='<p>'.$output.'</p>';
      } else {
      $message.=' '.&Apache::lonxml::xmlparse($r,'tex','<p>'.$output.'</p>').' ';
      }
    }
    }
    if ($allowed) {
    &Apache::lonfeedback::newline_to_br(\$urls);
    &Apache::lontemplate::print_start_template($r,$fields{$field}.
     &Apache::loncommon::help_open_topic('Syllabus_URLs'),'LC_Box');
    $r->print($urls);
    $r->print("<br /><div>");
    &Apache::lontemplate::print_textarea_template($r, $data{$field},
    $field, Apache::lontemplate->RICH_TEXT_ALWAYS_OFF);
    &Apache::lontemplate::print_saveall_template($r);                         
    $r->print("</div>");
    &Apache::lontemplate::print_end_template($r);
   
    } else {
    $r->print($message);
    }
    };
    my %custom_hash = ( 'lll_includeurl' => $url_include_handler );
    &Apache::lontemplate::print_template_fields($r, \%syllabus, \%syllabusfields, 
    $target, $allowed, Apache::lontemplate->RICH_TEXT_DETECT_HTML, \%custom_hash);
         if ($allowed) {          if ($allowed) {
         $r->print('</form>'.              $r->print('</form>'.
     &Apache::lonhtmlcommon::htmlareaselectactive(@htmlids));              &Apache::lonhtmlcommon::htmlareaselectactive());
         }          }
       # 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 class="LC_info">');} 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') {
           $r->print('</div>');
         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']).
                       '</form>');                        '</form>');
         }          }
     $r->print(&Apache::loncommon::end_page());          $r->print(&Apache::loncommon::end_page());
     } else {      } else {
     $r->print('\end{document}');          $r->print('\end{document}');
     }      }
     return OK;      return OK;
 }  }

Removed from v.1.90  
changed lines
  Added in v.1.113


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