--- loncom/interface/lonsyllabus.pm 2013/05/16 20:03:51 1.127 +++ loncom/interface/lonsyllabus.pm 2014/06/17 23:22:14 1.137 @@ -1,7 +1,7 @@ # The LearningOnline Network # Syllabus # -# $Id: lonsyllabus.pm,v 1.127 2013/05/16 20:03:51 raeburn Exp $ +# $Id: lonsyllabus.pm,v 1.137 2014/06/17 23:22:14 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -35,6 +35,7 @@ use Apache::loncommon; use Apache::lonnet; use Apache::lontexconvert; use Apache::lonfeedback; +use Apache::lonhtmlgateway; use Apache::lonannounce; use Apache::lonlocal; use Apache::lonhtmlcommon; @@ -53,7 +54,7 @@ sub handler { # ------------------------------------------------------------ Get query string &Apache::loncommon::get_unprocessed_cgi ($ENV{'QUERY_STRING'},['register','forceedit','todocs', - 'folderpath','title']); + 'folderpath','title','only_body']); # ----------------------------------------------------- Is this even a course? my $homeserver=&Apache::lonnet::homeserver($cnum,$cdom); if ($homeserver eq 'no_host') { @@ -73,12 +74,6 @@ sub handler { my %courseenv=&Apache::lonnet::dump('environment',$cdom,$cnum); my $crstype = &Apache::loncommon::course_type(); -# ------------------------------------------------------------ Print the screen - - if ($target eq 'tex') { - $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'})); - } - # --------------------------------------------------------------- Force Student my ($forceedit,$forcestudent); if ($env{'form.forceedit'}) { $forceedit=1; } @@ -103,8 +98,8 @@ sub handler { my $uploaded=$courseenv{'uploadedsyllabus'}; my $minimal=$courseenv{'minimalsyllabus'}; - if (($minimal =~/\w/) || ($uploaded =~/\w/)) { - my $item; + if (($minimal =~/\w/) || ($uploaded =~/\w/)) { + my ($item,$is_pdf); if ($minimal =~/\w/) { if ($external =~ m{\Q$minimal\E$}) { undef($external); @@ -115,6 +110,9 @@ sub handler { undef($external); } $item = $uploaded; + if ($item =~ /\.pdf$/i) { + $is_pdf = 1; + } } unless ($allowed && $forceedit) { my $file=&Apache::lonnet::filelocation("",$item); @@ -124,19 +122,32 @@ sub handler { if ($filecontents eq -1) { $r->print(&mt('Syllabus file unavailable')); } elsif ($filetype eq 'tex') { - my $result = &Apache::lontexconvert::converted(\$filecontents, - $env{'form.texengine'}); - my %args; - &get_breadcrumbs($cdom,$cnum,$crstype,\%args); - $r->print(&Apache::loncommon::start_page("Syllabus",undef,\%args). - $result. - &Apache::loncommon::end_page()); + if ($target eq 'tex') { + $r->print($filecontents); + } else { + my $result = &Apache::lontexconvert::converted(\$filecontents, + $env{'form.texengine'}); + my %args; + &get_breadcrumbs($cdom,$cnum,$crstype,\%args); + if ($env{'form.only_body'}) { + $args{'only_body'} = 1; + } + if ($env{'request.use_absolute'}) { + $args{'use_absolute'} = $env{'request.use_absolute'}; + } + $r->print(&Apache::loncommon::start_page("Syllabus",undef,\%args). + $result. + &Apache::loncommon::end_page()); + } } else { my %mystyle; + unless ($target eq 'tex') { + $target = 'web'; + } &Apache::structuretags::reset_problem_globals(); my $oldfile = $env{'request.filename'}; $env{'request.filename'} = $item; - my $result = &Apache::lonxml::xmlparse($r,'web',$filecontents, + my $result = &Apache::lonxml::xmlparse($r,$target,$filecontents, '',%mystyle); &Apache::structuretags::reset_problem_globals(); &Apache::lonhomework::finished_parsing(); @@ -145,17 +156,44 @@ sub handler { $r->print($result); } } else { - $r->print(&Apache::lonwrapper::wrapper($item)); + if ($target eq 'tex') { + $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}). + ' \strut \\\\ \textbf{'.&mt('Syllabus').'} \strut \\\\ '. + &mt('Unsupported file type.').' \strut \\\\ '. + &mt('Print the syllabus directly from your web browser'). + '\end{document}'); + } else { + $r->print(&Apache::lonwrapper::wrapper($item,undef,$env{'request.use_absolute'}, + undef,$is_pdf,&mt('Syllabus'))); + } } return OK; } } elsif ($external=~/\w/) { unless ($allowed && $forceedit) { - $r->print(&Apache::lonwrapper::wrapper($external)); + if ($target eq 'tex') { + $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'}). + ' \strut \\\\ \textbf{'.&mt('Syllabus').'} \strut \\\\ '.$external.' '. + ' \strut \\\\ '.&mt('Print the syllabus directly from your web browser'). + '\end{document}'); + } else { + my $is_ext = 1; + my $is_pdf; + if ($external =~ /\.pdf$/i) { + $is_pdf = 1; + } + $r->print(&Apache::lonwrapper::wrapper($external,undef,$env{'request.use_absolute'}, + $is_ext,$is_pdf,&mt('Syllabus'))); + } return OK; } } +# ------------------------------------------------------------ Print the screen + + if ($target eq 'tex') { + $r->print(&Apache::lonprintout::print_latex_header($env{'form.latex_type'})); + } # ------------------------------ The buck stops here: internal syllabus display # --------------------------------------------------------- The syllabus fields @@ -385,7 +423,7 @@ sub handler { } $rsslinktext = &mt('Manage Course RSS Feeds/Blogs'); if ($crstype eq 'Community') { - $rsslinktext = &mt('Manage Communiity RSS Feeds/Blogs'); + $rsslinktext = &mt('Manage Community RSS Feeds/Blogs'); } } my $editurl= &Apache::lonnet::absolute_url().'/adm/'.$cdom.'/'.$cnum.'/_rss.html'; @@ -406,10 +444,6 @@ sub handler { } # ---------------------------------------------------------------- Get syllabus if (($syllabus{'uploaded.lastmodified'}) || ($allowed)) { - if ($allowed) { - $r->print('
'); - } - my $url_include_handler = sub { my ($r, $field, $message, $group, $data_ref, $fields_ref, $target, $allowed, $display) = @_; my %data = %{$data_ref}; @@ -456,7 +490,7 @@ sub handler { $target, $allowed, Apache::lontemplate->RICH_TEXT_DETECT_HTML, \%custom_hash, undef,\%displayfields,\%noshow); if ($allowed) { - $r->print('
'. + $r->print(''. &Apache::lonhtmlcommon::htmlareaselectactive()); } } else { @@ -674,6 +708,13 @@ ENDSCRIPT onload => 'setTemplateBoxes();', ); $args->{'add_entries'} = \%loaditem; + } else { + if ($env{'request.use_absolute'}) { + $args->{'use_absolute'} = $env{'request.use_absolute'}; + } + } + if ($env{'form.only_body'}) { + $args->{'only_body'} = 1; } my $start_page = &Apache::loncommon::start_page("Syllabus", $rss_link.$js,$args); @@ -1011,7 +1052,7 @@ sub get_personnel { } if ($allowed) { my $item = '