--- loncom/interface/lonsyllabus.pm 2013/05/16 20:03:51 1.127 +++ loncom/interface/lonsyllabus.pm 2013/09/21 23:44:46 1.134 @@ -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.134 2013/09/21 23:44:46 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,7 +98,7 @@ sub handler { my $uploaded=$courseenv{'uploadedsyllabus'}; my $minimal=$courseenv{'minimalsyllabus'}; - if (($minimal =~/\w/) || ($uploaded =~/\w/)) { + if (($minimal =~/\w/) || ($uploaded =~/\w/)) { my $item; if ($minimal =~/\w/) { if ($external =~ m{\Q$minimal\E$}) { @@ -124,19 +119,29 @@ 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; + } + $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 +150,37 @@ 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)); + } } 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 { + $r->print(&Apache::lonwrapper::wrapper($external)); + } 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 @@ -406,10 +431,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 +477,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 { @@ -675,6 +696,9 @@ ENDSCRIPT ); $args->{'add_entries'} = \%loaditem; } + if ($env{'form.only_body'}) { + $args->{'only_body'} = 1; + } my $start_page = &Apache::loncommon::start_page("Syllabus", $rss_link.$js,$args); if ($start_page) { @@ -1011,7 +1035,7 @@ sub get_personnel { } if ($allowed) { my $item = '