--- loncom/publisher/Attic/lonconstruct.pm 2003/06/06 02:24:49 1.11 +++ loncom/publisher/Attic/lonconstruct.pm 2008/11/19 19:15:02 1.35 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # Construction Space Page Wrapper for Construction # -# $Id: lonconstruct.pm,v 1.11 2003/06/06 02:24:49 www Exp $ +# $Id: lonconstruct.pm,v 1.35 2008/11/19 19:15:02 jms Exp $ # # Copyright Michigan State University Board of Trustees # @@ -26,28 +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(); -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 @@ -69,23 +65,24 @@ 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 @@ -94,26 +91,62 @@ 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); + $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'; + } + +# +# Checking to see if we should display the topframe +# + my $toprows = 0; + my $topsrc = ''; + if ($env{'environment.remote'} ne 'off') { + $toprows = '110'; + $topsrc = '/adm/localize/adm/publisher.html'; + } + + my $js=qq| + + |; + + my $start_page= + &Apache::loncommon::start_page('Construction Space',$js, + {'frameset' => 1, + 'add_entries' => { + 'rows' => "$toprows,*", + 'border' => "0",}}); + my $end_page= + &Apache::loncommon::end_page({'frameset' => 1}); $r->print(< -LON-CAPA Construction Space - - - - - +$start_page + + +$end_page ENDPAGE return OK; }