--- loncom/publisher/Attic/lonconstruct.pm 2003/05/28 21:07:19 1.10 +++ loncom/publisher/Attic/lonconstruct.pm 2010/03/10 21:26:04 1.36 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Construction Space Page Wrapper for Construction # -# $Id: lonconstruct.pm,v 1.10 2003/05/28 21:07:19 www Exp $ +# $Id: lonconstruct.pm,v 1.36 2010/03/10 21:26:04 droeschl Exp $ # # Copyright Michigan State University Board of Trustees # @@ -26,30 +26,24 @@ # http://www.lon-capa.org/ # # -# (Page Handler -# -# (TeX Content Handler -# -# 05/29/00,05/30 Gerd Kortemeyer) -# 08/30,08/31,09/06,09/14,09/15,09/16,09/19,09/20,09/21,09/23, -# 10/02,10/10,10/14,10/16,10/18,10/19,10/31,11/6,11/14,11/16 Gerd Kortemeyer) -# -# 11/22,11/23,11/28, -# 03/30/01 Gerd Kortemeyer -package Apache::lonconstruct; - -use strict; -use Apache::Constants qw(:common :http :methods); -use Apache::lonnet; -use Apache::Log (); -use HTML::Entities(); -use Apache::loncommon; -use Apache::lonmenu; -my $DEBUG = 0; =pod +=head1 + +=head1 NAME + +Apache::lonconstruct + +=head1 SYNOPSIS + +Page wrapper for handling construction space. + +This is part of the LearningOnline Network with CAPA project +described at http://www.lon-capa.org. + + =item Debug($request, $message) If debugging is enabled puts out a debuggin message determined by the @@ -71,24 +65,25 @@ my $DEBUG = 0; =cut -sub Debug { - - # Marshall the parameters. - - my $r = shift; - my $log = $r->log; - my $message = shift; - - # Put out the indicated message butonly if DEBUG is false. - - if ($DEBUG) { - $log->debug($message); - } -} +package Apache::lonconstruct; + +use strict; +use Apache::Constants qw(:common :http :methods); +use Apache::lonnet; +use HTML::Entities(); +my $DEBUG = 0; +sub Debug { + # Put out the indicated message but only if DEBUG is true. + if ($DEBUG) { + my ($r,$message) = @_; + $r->log_reason($message); + } +} + # ================================================================ Main Handler sub handler { @@ -96,32 +91,54 @@ sub handler { # -------------------------------------------------------------- Build frameset - $r->content_type('text/html'); + &Apache::loncommon::content_type($r,'text/html'); $r->send_http_header; return OK if $r->header_only; my $lowerframe=$r->path_info; - &Debug($r, "Initial URL for lower frame: ".$lowerframe); $lowerframe=~s/^\//\/\~/; &Debug($r, "Lower frame URL afer ~ subst: ".$lowerframe); - $lowerframe= &HTML::Entities::encode($lowerframe); - &Debug($r, "LOwer frame URL after quote subst: ".$lowerframe); - my $loadevents=&Apache::lonmenu::loadevents(); - my $unloadevents=&Apache::lonmenu::unloadevents(); - my $script=&Apache::lonmenu::registerurl(); + $lowerframe= &HTML::Entities::encode($lowerframe,'<>&"'); + &Debug($r, "Lower frame URL after quote subst: ".$lowerframe); + +# +# Are we forcing edit mode? +# + + &Apache::loncommon::get_unprocessed_cgi + ($ENV{'QUERY_STRING'},['forceedit']); + if ($env{'form.forceedit'}) { + $lowerframe.='?editmode=Edit&problemmode=editxml'; + } + &Apache::loncommon::get_unprocessed_cgi + ($ENV{'QUERY_STRING'},['forceColoredit']); + if ($env{'form.forceColoredit'}) { + $lowerframe.='?editmode=Edit&problemmode=edit'; + } + + my $js=qq| + + |; + + my $start_page= + &Apache::loncommon::start_page('Construction Space',$js, + {'frameset' => 1, + 'add_entries' => { + 'rows' => "0,*", + 'border' => "0",}}); + my $end_page= + &Apache::loncommon::end_page({'frameset' => 1}); + + +#SD this entire frameset should be obsolete?! $r->print(< -LON-CAPA Construction Space -$script - - - - - - +$start_page + + +$end_page ENDPAGE return OK; }