version 1.115, 2002/09/23 17:19:24
|
version 1.198, 2003/07/17 18:42:13
|
Line 29
|
Line 29
|
# 6/26/2001 fixed extra web display at end of <web></web> tags |
# 6/26/2001 fixed extra web display at end of <web></web> tags |
# 8/17,8/18,8/20 Gerd Kortemeyer |
# 8/17,8/18,8/20 Gerd Kortemeyer |
|
|
|
|
package Apache::structuretags; |
package Apache::structuretags; |
|
|
use strict; |
use strict; |
use Apache::lonnet; |
use Apache::lonnet; |
use Apache::File(); |
use Apache::File(); |
|
use Apache::lonmenu; |
|
|
BEGIN { |
BEGIN { |
&Apache::lonxml::register('Apache::structuretags',('block','while','randomlist','problem','library','web','tex','part','preduedate','postanswerdate','solved','notsolved','startouttext','endouttext')); |
&Apache::lonxml::register('Apache::structuretags',('block','languageblock','instructorcomment','while','randomlist','problem','library','web','tex','part','preduedate','postanswerdate','solved','notsolved','startouttext','endouttext', |
# &Apache::lonxml::register_insert('problem','',('part','postanswerdate','preduedate')) |
'simpleeditbutton','definetag')); |
} |
} |
|
|
sub start_web { |
sub start_web { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $bodytext=&Apache::lonxml::get_all_text("/web",$$parser[$#$parser]); |
if (!($target eq 'web' || $target eq 'edit' || $target eq 'modified' || |
if ($target eq 'web') { |
$target eq 'answer' || $target eq 'grade' || $target eq 'meta' )) { |
return $bodytext; |
my $bodytext=&Apache::lonxml::get_all_text("/web",$parser); |
} |
} |
return ''; |
return ''; |
} |
} |
|
|
sub end_web { |
sub end_web { |
Line 54 sub end_web {
|
Line 56 sub end_web {
|
} |
} |
|
|
sub start_tex { |
sub start_tex { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $bodytext=&Apache::lonxml::get_all_text("/tex",$$parser[$#$parser]); |
my $result=''; |
if ($target eq 'tex') { |
if (!($target eq 'edit' || $target eq 'modified' || |
return $bodytext.' '; |
$target eq 'answer' || $target eq 'grade' || $target eq 'meta' )) { |
} |
&Apache::lonxml::debug("tex 1"); |
return ''; |
my $bodytext=&Apache::lonxml::get_all_text("/tex",$parser); |
|
} elsif ($target eq 'tex') { |
|
$result=&Apache::lonxml::get_all_text("/tex",$parser); |
|
} |
|
return $result;; |
} |
} |
|
|
sub end_tex { |
sub end_tex { |
Line 67 sub end_tex {
|
Line 73 sub end_tex {
|
} |
} |
|
|
sub page_start { |
sub page_start { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my %found; |
my %found; |
foreach my $taginside ($tagstack) { |
foreach my $taginside ($tagstack) { |
foreach my $taglookedfor ('html','body','form') { |
foreach my $taglookedfor ('html','body','form') { |
if ($taginside =~ /^$taglookedfor$/i) { $found{$taglookedfor} = 1; } |
if ($taginside =~ /^$taglookedfor$/i) {$found{$taglookedfor} = 1;} |
} |
} |
} |
} |
|
|
my $result; |
my $result; |
my $head_tag_start; |
my $head_tag_start; |
if (!defined($found{'html'})) { |
if (!defined($found{'html'})) { |
$result=&Apache::londefdef::start_html($target,$token,$tagstack,$parstack, |
$result=&Apache::londefdef::start_html($target,$token,$tagstack, |
$parser,$safeeval); |
$parstack,$parser,$safeeval); |
$head_tag_start='<head>'.&Apache::lonxml::registerurl(undef,$target); |
$head_tag_start='<head>'.&Apache::lonmenu::registerurl(undef,$target); |
} |
} |
my $body_tag_start; |
my $body_tag_start; |
if (!defined($found{'body'})) { |
if (!defined($found{'body'})) { |
$body_tag_start='<body onLoad="'.&Apache::lonxml::loadevents().'" '. |
$body_tag_start='<body onLoad="'.&Apache::lonmenu::loadevents().'" '. |
'onUnload="'.&Apache::lonxml::unloadevents().'" '; |
'onUnload="'.&Apache::lonmenu::unloadevents().'" '; |
my $background=&Apache::lonxml::get_param('background',$parstack,$safeeval); |
my $background=&Apache::lonxml::get_param('background',$parstack, |
if ($background) { |
$safeeval); |
$Apache::lonxml::extlinks[$#Apache::lonxml::extlinks+1]= |
if ($background) { |
$background; |
$Apache::lonxml::extlinks[$#Apache::lonxml::extlinks+1]= |
$body_tag_start.='background="'.$background.'" '; |
$background; |
} else { |
$body_tag_start.='background="'.$background.'" '; |
my $bgcolor=&Apache::lonxml::get_param('bgcolor',$parstack,$safeeval); |
} else { |
if ($bgcolor) { |
my $bgcolor=&Apache::lonxml::get_param('bgcolor',$parstack, |
$body_tag_start.='bgcolor="'.$bgcolor.'" '; |
$safeeval); |
} else { |
if ($bgcolor) { |
$body_tag_start.='bgcolor="#ffffff"'; |
$body_tag_start.='bgcolor="'.$bgcolor.'" '; |
} |
} else { |
} |
$body_tag_start.='bgcolor="#ffffff"'; |
$body_tag_start.='>'; |
} |
} |
} |
my $form_tag_start; |
$body_tag_start.='>'.&Apache::lonmenu::menubuttons(undef,$target,1); |
if (!defined($found{'form'})) { |
if ($target eq 'web' && $ENV{'request.state'} ne 'construct') { |
$form_tag_start='<form name="lonhomework" method="POST" action="'. |
my ($symb,undef,undef,undef,$publicuser)= |
$ENV{'request.uri'}.'">'; |
&Apache::lonxml::whichuser(); |
} |
if ($symb eq '' && !$publicuser) { |
return ($result,$head_tag_start,$body_tag_start,$form_tag_start); |
my $help = &Apache::loncommon::help_open_topic("Ambiguous_Reference"); |
|
$help="Browsing resource, all submissions are temporary.<br />"; |
|
$body_tag_start.=$help; |
|
} |
|
} |
|
} |
|
my $form_tag_start; |
|
if (!defined($found{'form'})) { |
|
$form_tag_start='<form name="lonhomework" method="POST" action="'. |
|
$ENV{'request.uri'}.'">'; |
|
} |
|
return ($result,$head_tag_start,$body_tag_start,$form_tag_start); |
} |
} |
|
|
|
#use Time::HiRes(); |
sub get_resource_name { |
sub get_resource_name { |
my ($parstack,$safeeval)=@_; |
my ($parstack,$safeeval)=@_; |
my $name=&Apache::lonxml::get_param('name',$parstack,$safeeval); |
my $name=&Apache::lonnet::gettitle(); |
if ($name eq '') { |
if ($name eq '') { |
$name=&Apache::lonnet::EXT('resource.title'); |
$name=&Apache::lonnet::EXT('resource.title'); |
if ($name eq 'con_lost') { $name = ''; } |
if ($name eq 'con_lost') { $name = ''; } |
} |
} |
$Apache::lonhomework::name=$name; |
$Apache::lonhomework::name=$name; |
return $name; |
return $name; |
} |
} |
|
|
sub setup_rndseed { |
sub setup_rndseed { |
my ($safeeval)=@_; |
my ($safeeval)=@_; |
my $rndseed; |
my $rndseed; |
if ($ENV{'request.state'} eq "construct") { |
my ($symb)=&Apache::lonxml::whichuser(); |
$rndseed=$ENV{'form.rndseed'}; |
if ($ENV{'request.state'} eq "construct" || $symb eq '') { |
if (!$rndseed) { |
$rndseed=$ENV{'form.rndseed'}; |
$rndseed=time; |
if (!$rndseed) { |
$ENV{'form.rndseed'}=$rndseed; |
$rndseed=$Apache::lonhomework::history{'rndseed'}; |
} |
if (!$rndseed) { |
&Apache::run::run('$external::randomseed='.$rndseed.';',$safeeval); |
$rndseed=time; |
} |
$ENV{'form.rndseed'}=$rndseed; |
return $rndseed; |
} |
|
} |
|
if ($ENV{'form.resetdata'} eq 'New Problem Variation' || |
|
$ENV{'form.newrandomization'} eq 'New Randomization') { |
|
srand(time); |
|
$rndseed=int(rand(2100000000)); |
|
$ENV{'form.rndseed'}=$rndseed; |
|
delete($ENV{'form.resetdata'}); |
|
delete($ENV{'form.newrandomization'}); |
|
} |
|
if (defined($rndseed) && $rndseed ne int($rndseed)) { |
|
$rndseed=join(',',&Math::Random::random_seed_from_phrase($rndseed)); |
|
} |
|
&Apache::lonxml::debug("Setting rndseed to $rndseed"); |
|
&Apache::run::run('$external::randomseed='.$rndseed.';',$safeeval); |
|
} |
|
return $rndseed; |
} |
} |
|
|
sub problem_edit_header { |
sub problem_edit_header { |
return '<input type="hidden" name="submitted" value="edit" /> |
return '<input type="hidden" name="submitted" value="edit" /> |
<input type="hidden" name="problemmode" value="Edit" /> |
<input type="hidden" name="problemmode" value="Edit" /> |
<input type="submit" name="problemmode" value="Discard Edits and View" /> |
<input type="submit" name="problemmode" value="Discard Edits and View" /> |
<input type="submit" name="problemmode" value="EditXML" /> |
<input type="submit" name="problemmode" value="EditXML" /> |
<input type="submit" name="Undo" value="undo" /> <hr /> |
<input type="submit" name="Undo" value="undo" /> <hr /> |
<input type="submit" name="submit" value="Submit Changes" /> |
<input type="submit" name="submit" value="Submit Changes and Edit" /> |
<input type="submit" name="submit" value="Submit Changes and View" /><br /> |
<input type="submit" name="submit" value="Submit Changes and View" /><br /><p> </p><table border="0"><tr><td bgcolor="#DDDDDD"> |
'; |
'; |
} |
} |
|
|
sub problem_edit_footer { |
sub problem_edit_footer { |
return '<br /><input type="submit" name="submit" value="Submit Changes and Edit" /> |
return '</td></tr></table><br /><input type="submit" name="submit" value="Submit Changes and Edit" /> |
<input type="submit" name="submit" value="Submit Changes and View" />'; |
<input type="submit" name="submit" value="Submit Changes and View" />'; |
} |
} |
|
|
sub problem_web_to_edit_header { |
sub problem_web_to_edit_header { |
my ($rndseed)=@_; |
my ($rndseed)=@_; |
my $result.='<input type="hidden" name="problemmode" value="View" /> |
my $result.='<input type="hidden" name="problemmode" value="View" /> |
<input type="submit" name="problemmode" value="Edit" /> |
<input type="submit" name="problemmode" value="Edit" /> |
<input type="submit" name="problemmode" value="EditXML" /> |
<input type="submit" name="problemmode" value="EditXML" /> |
Random Seed:<input type="text" name="rndseed" width="10" value="'. |
<input type="submit" name="newrandomization" value="New Randomization" /> |
$rndseed.'" /> |
|
<input type="submit" name="changerandseed" value="Change" /> |
|
<input type="submit" name="resetdata" value="Reset Submissions" /> |
<input type="submit" name="resetdata" value="Reset Submissions" /> |
|
<nobr><input type="submit" name="changerandseed" value="Change Random Seed To:" /> |
|
<input type="text" name="rndseed" width="10" value="'. |
|
$rndseed.'" |
|
onChange="javascript:document.lonhomework.changerandseed.click()" /></nobr> |
<input type="checkbox" name="showallfoils" '; |
<input type="checkbox" name="showallfoils" '; |
if (defined($ENV{'form.showallfoils'})) { $result.='checked="on"'; } |
if (defined($ENV{'form.showallfoils'})) { $result.='checked="on"'; } |
$result.= ' /> Show All Foils |
$result.= ' /> Show All Foils |
<hr />'; |
<hr />'; |
|
my $numtoanalyze=$ENV{'form.numtoanalyze'}; |
|
if (!$numtoanalyze) { $numtoanalyze=20; } |
|
$result.= '<input type="submit" name="problemmode" value="Calculate answers" /> for |
|
<input type="text" name="numtoanalyze" value="'. |
|
$numtoanalyze.'" size="5" /> versions of this problem.'. |
|
&Apache::loncommon::help_open_topic("Analyze_Problem", |
|
'',undef,undef,300). |
|
'<hr />'; |
|
return $result; |
} |
} |
|
|
sub initialize_storage { |
sub initialize_storage { |
%Apache::lonhomework::results=(); |
%Apache::lonhomework::results=(); |
my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser(); |
%Apache::lonhomework::history=(); |
if ($ENV{'request.state'} eq 'construct') { |
my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser(); |
%Apache::lonhomework::history= |
if ($ENV{'request.state'} eq 'construct' || $symb eq '') { |
&Apache::lonnet::tmprestore($ENV{'request.uri'},'',$domain,$name); |
%Apache::lonhomework::history= |
|
&Apache::lonnet::tmprestore($ENV{'request.uri'},'',$domain,$name); |
|
my ($temp)=keys %Apache::lonhomework::history ; |
|
&Apache::lonxml::debug("Return message of $temp"); |
|
} else { |
|
%Apache::lonhomework::history= |
|
&Apache::lonnet::restore($symb,$courseid,$domain,$name); |
|
} |
|
#ignore error conditions |
my ($temp)=keys %Apache::lonhomework::history ; |
my ($temp)=keys %Apache::lonhomework::history ; |
&Apache::lonxml::debug("Return message of $temp"); |
if ($temp =~ m/^error:.*/) { %Apache::lonhomework::history=(); } |
} else { |
|
%Apache::lonhomework::history= |
|
&Apache::lonnet::restore($symb,$courseid,$domain,$name); |
|
} |
|
#ignore error conditions |
|
my ($temp)=keys %Apache::lonhomework::history ; |
|
if ($temp =~ m/^error:.*/) { %Apache::lonhomework::history=(); } |
|
} |
} |
|
|
# -------------------------------------------------------------finalize_storage |
# -------------------------------------------------------------finalize_storage |
Line 187 sub initialize_storage {
|
Line 233 sub initialize_storage {
|
# checks form.grade_ for specific values, other wises stores |
# checks form.grade_ for specific values, other wises stores |
# to the running users environment |
# to the running users environment |
sub finalize_storage { |
sub finalize_storage { |
my $result; |
my $result; |
my ($temp) = keys %Apache::lonhomework::results; |
my ($temp) = keys %Apache::lonhomework::results; |
if ( $temp ne '' ) { |
if ( $temp ne '' ) { |
my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser(); |
my ($symb,$courseid,$domain,$name) = &Apache::lonxml::whichuser(); |
if ($ENV{'request.state'} eq 'construct') { |
if ($ENV{'request.state'} eq 'construct' || $symb eq '') { |
$result=&Apache::lonnet::tmpstore(\%Apache::lonhomework::results, |
$Apache::lonhomework::results{'rndseed'}=$ENV{'form.rndseed'}; |
$ENV{'request.uri'},'',$domain,$name); |
$result=&Apache::lonnet::tmpstore(\%Apache::lonhomework::results, |
&Apache::lonxml::debug('Construct Store return message:'.$result); |
$ENV{'request.uri'},'',$domain,$name); |
} else { |
&Apache::lonxml::debug('Construct Store return message:'.$result); |
$result=&Apache::lonnet::cstore(\%Apache::lonhomework::results, |
} else { |
$symb,$courseid,$domain,$name); |
$result=&Apache::lonnet::cstore(\%Apache::lonhomework::results, |
&Apache::lonxml::debug('Store return message:'.$result); |
$symb,$courseid,$domain,$name); |
|
&Apache::lonxml::debug('Store return message:'.$result); |
|
} |
} |
} |
} |
return $result; |
return $result; |
|
} |
} |
|
|
sub checkout_msg { |
sub checkout_msg { |
return (<<ENDCHECKOUT); |
return (<<ENDCHECKOUT); |
<h2>The resource needs to be checked out</h2> |
<h2>The resource needs to be checked out</h2> |
As a resource gets checked out, a unique timestamped ID is given to it, and a |
As a resource gets checked out, a unique timestamped ID is given to it, and a |
permanent record is left in the system.<p /> |
permanent record is left in the system.<p /> |
Line 221 ENDCHECKOUT
|
Line 268 ENDCHECKOUT
|
} |
} |
|
|
sub start_problem { |
sub start_problem { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
|
# meta is called from lonpublisher, which doesn't uses the normal |
if ( $Apache::inputtags::part ne '' || |
# lonhomework method of parsing the file which means that inputtags |
$Apache::lonhomework::parsing_a_problem) { |
# won't get reset |
&Apache::lonxml::error('Only one <problem> allowed in a .problem file'); |
if ( $Apache::inputtags::part ne '' && $target != 'meta' ) { |
#my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser); |
&Apache::lonxml::error('Only one problem allowed in a .problem file'); |
return ''; |
my $bodytext=&Apache::lonxml::get_all_text("/problem",$$parser[-1]); |
} |
return ''; |
|
} |
$Apache::lonhomework::parsing_a_problem=1; |
#intialize globals |
#initialize globals |
$Apache::inputtags::part='0'; |
$Apache::inputtags::part='0'; |
@Apache::inputtags::responselist = (); |
@Apache::inputtags::partlist=('0'); |
@Apache::inputtags::previous=(); |
@Apache::inputtags::responselist = (); |
if ($target ne 'analyze') { |
@Apache::inputtags::importlist = (); |
&initialize_storage(); |
@Apache::inputtags::previous=(); |
if ($target eq 'web') { |
@Apache::inputtags::previous_version=(); |
&Apache::lonhomework::showhash(%Apache::lonhomework::history); |
$Apache::structuretags::printanswer='No'; |
} |
@Apache::structuretags::whileconds=(); |
$Apache::lonhomework::type=&Apache::lonnet::EXT('resource.0.type'); |
@Apache::structuretags::whilebody=(); |
&Apache::lonxml::debug("Found this to be of type :$Apache::lonhomework::type:"); |
@Apache::structuretags::whileline=(); |
} |
$Apache::lonhomework::scantronmode=0; |
if ($Apache::lonhomework::type eq '') { |
$Apache::lonhomework::problemstatus= |
my $uri=$ENV{'request.uri'}; |
&Apache::lonnet::EXT('resource.0.problemstatus'); |
if ($uri=~/\.(\w+)$/) { |
|
$Apache::lonhomework::type=$1; |
if (defined($ENV{'scantron.maxquest'})) { |
&Apache::lonxml::debug("Using type of $1"); |
$Apache::lonhomework::scantronmode=1; |
} else { |
} |
$Apache::lonhomework::type='problem'; |
|
&Apache::lonxml::debug("Using default type, problem, :$uri:"); |
if ($target ne 'analyze') { |
|
&initialize_storage(); |
|
if ($target eq 'web') { |
|
&Apache::lonhomework::showhash(%Apache::lonhomework::history); |
|
} |
|
$Apache::lonhomework::type=&Apache::lonnet::EXT('resource.0.type'); |
|
&Apache::lonxml::debug("Found this to be of type :$Apache::lonhomework::type:"); |
|
} |
|
if ($Apache::lonhomework::type eq '' ) { |
|
my $uri=$ENV{'request.uri'}; |
|
if ($uri=~/\.(\w+)$/) { |
|
$Apache::lonhomework::type=$1; |
|
&Apache::lonxml::debug("Using type of $1"); |
|
} else { |
|
$Apache::lonhomework::type='problem'; |
|
&Apache::lonxml::debug("Using default type, problem, :$uri:"); |
|
} |
} |
} |
} |
|
|
|
#added vars to the scripting enviroment |
#added vars to the scripting enviroment |
my $expression='$external::part='.$Apache::inputtags::part.';'; |
my $expression='$external::part='.$Apache::inputtags::part.';'; |
&Apache::run::run($expression,$safeeval); |
|
my $status; |
|
my $accessmsg; |
|
|
|
#should get back a <html> or the neccesary stuff to start XML/MathML |
|
my ($result,$head_tag_start,$body_tag_start,$form_tag_start)= |
|
&page_start($target,$token,$tagstack,$parstack,$parser,$safeeval); |
|
if ($target eq 'tex' and $ENV{'request.symb'} =~ m/\.page_/) { $result = '';} |
|
|
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') { |
|
#handle exam checkout |
|
if ($Apache::lonhomework::type eq 'exam') { |
|
my $token=$Apache::lonhomework::history{"resource.0.outtoken"}; |
|
if (($ENV{'form.doescheckout'}) && (!$token)) { |
|
$token=&Apache::lonxml::maketoken(); |
|
$Apache::lonhomework::history{"resource.0.outtoken"}=$token; |
|
} |
|
$body_tag_start.=&Apache::lonxml::printtokenheader($target,$token); |
|
} |
|
|
|
#handle rand seed in construction space |
|
my $rndseed=&setup_rndseed($safeeval); |
|
($status,$accessmsg) = &Apache::lonhomework::check_access('0'); |
|
push (@Apache::inputtags::status,$status); |
|
my $expression='$external::datestatus="'.$status.'";'; |
|
$expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.0.solved"}.'";'; |
|
&Apache::run::run($expression,$safeeval); |
&Apache::run::run($expression,$safeeval); |
if (( $status eq 'CLOSED' ) || |
my $status; |
( $status eq 'UNCHECKEDOUT') || |
my $accessmsg; |
( $status eq 'BANNED')) { |
|
my $bodytext=&Apache::lonxml::get_all_text("/problem",$$parser[$#$parser]); |
#should get back a <html> or the neccesary stuff to start XML/MathML |
if ( $target eq "web" ) { |
my ($result,$head_tag_start,$body_tag_start,$form_tag_start)= |
$result.= $head_tag_start.'</head>'; |
&page_start($target,$token,$tagstack,$parstack,$parser,$safeeval); |
my $msg=$body_tag_start. |
if ($target eq 'tex' and $ENV{'request.symb'} =~ m/\.page_/) {$result='';} |
'<h1>Not open to be viewed</h1>'; |
|
if ($status eq 'CLOSED') { |
if ($target eq 'analyze') { my $rndseed=&setup_rndseed($safeeval); } |
$msg.='The problem '.$accessmsg; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
} elsif ($status eq 'UNCHECKEDOUT') { |
$target eq 'tex') { |
$msg.=&checkout_msg; |
#handle exam checkout |
} |
if ($Apache::lonhomework::type eq 'exam') { |
$result.=$msg.'<br />'; |
my $token= |
} |
$Apache::lonhomework::history{"resource.0.outtoken"}; |
} elsif ($target eq 'web') { |
if (($ENV{'form.doescheckout'}) && (!$token)) { |
my $name= &get_resource_name($parstack,$safeeval); |
$token=&Apache::lonxml::maketoken(); |
if ($status eq 'CAN_ANSWER') { |
$Apache::lonhomework::history{"resource.0.outtoken"}= |
# create a page header and exit |
$token; |
$result.="$head_tag_start<title>$name</title></head> |
} |
$body_tag_start \n $form_tag_start". |
$body_tag_start.=&Apache::lonxml::printtokenheader($target,$token); |
'<input type="hidden" name="submitted" value="yes" />'; |
} |
if ($ENV{'request.state'} eq "construct") { |
|
$result.= &problem_web_to_edit_header($rndseed); |
#handle rand seed in construction space |
} |
my $rndseed=&setup_rndseed($safeeval); |
# if we are viewing someone else preserve that info |
my ($symb)=&Apache::lonxml::whichuser(); |
if (defined $ENV{'form.grade_symb'}) { |
if ($ENV{'request.state'} ne "construct" && $symb eq '') { |
foreach my $field ('symb','courseid','domain','username') { |
$form_tag_start.='<input type="hidden" name="rndseed" value="'. |
$result .= '<input type="hidden" name="grade_'.$field. |
$rndseed.'" />'. |
'" value="'.$ENV{"form.grade_$field"}.'" />'."\n"; |
'<input type="submit" name="resetdata" |
} |
value="New Problem Variation" />'. |
} |
'<input type="hidden" name="username" |
} elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER' |
value="'.$ENV{'form.username'}.'" /> <br />'; |
|| $status eq 'CLOSED') { |
|
$result.=$head_tag_start. |
|
"<title>$name</title></head>\n$body_tag_start\n"; |
|
} |
|
} elsif ($target eq 'tex') { |
|
my $name= &Apache::lonxml::get_param('name',$parstack,$safeeval); |
|
if ($name eq '') { |
|
$name=&Apache::lonnet::EXT('resource.title'); |
|
if ($name eq 'con_lost') { $name = ''; } |
|
} |
|
$Apache::lonhomework::name=$name; |
|
my $id = $Apache::inputtags::part; |
|
my $duedate = &Apache::lonnet::EXT("resource.$id.duedate"); |
|
$duedate = POSIX::strftime("%c",localtime($duedate)); |
|
my $temp_file; |
|
my $filename = "/home/httpd/prtspool/$ENV{'user.name'}_$ENV{'user.domain'}_printout.due"; |
|
if (-e $filename) { |
|
$temp_file = Apache::File->new($filename); |
|
} else { |
|
$temp_file = Apache::File->new('>>'.$filename); |
|
} |
} |
my @due_file_content = <$temp_file>; |
($status,$accessmsg) = &Apache::lonhomework::check_access('0'); |
my $due_file_content = $due_file_content[$#due_file_content]; |
push (@Apache::inputtags::status,$status); |
chomp $due_file_content; |
my $expression='$external::datestatus="'.$status.'";'; |
if ($due_file_content ne $duedate) { |
$expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.0.solved"}.'";'; |
$temp_file = Apache::File->new('>'.$filename); |
&Apache::run::run($expression,$safeeval); |
print $temp_file "$duedate\n"; |
&Apache::lonxml::debug("Got $status"); |
if (not $ENV{'request.symb'} =~ m/\.page_/) { |
if (( $status eq 'CLOSED' ) || |
if(not $duedate=~m/1969/) { |
( $status eq 'UNCHECKEDOUT') || |
$result .= '\begin{document} \noindent\textit{Due date: '.$duedate.'} \vskip 1 mm'; |
( $status eq 'BANNED') || |
|
( $status eq 'UNAVAILABLE')) { |
|
my $bodytext=&Apache::lonxml::get_all_text("/problem",$parser); |
|
if ( $target eq "web" ) { |
|
$result.= $head_tag_start.'</head>'; |
|
my $msg=$body_tag_start; |
|
if ($status eq 'UNAVAILABLE') { |
|
$result.='<h1>Unable to determine if this resource is open due to network problems. Please try again later.</h1>'; |
} else { |
} else { |
$result .= '\begin{document} \noindent \vskip 1 mm'; |
$result.='<h1>Not open to be viewed</h1>'; |
} |
} |
|
if ($status eq 'CLOSED') { |
|
$msg.='The problem '.$accessmsg; |
|
} elsif ($status eq 'UNCHECKEDOUT') { |
|
$msg.=&checkout_msg; |
|
} |
|
$result.=$msg.'<br />'; |
|
} elsif ($target eq 'tex') { |
|
$result.='\begin{document}\noindent \vskip 1 mm \begin{minipage}{\textwidth}\vskip 0 mm'; |
|
if ($status eq 'UNAVAILABLE') { |
|
$result.='Unable to determine if this resource is open due to network problems. Please try again later.\vskip 0 mm '; |
|
} else { |
|
$result.="Problem is not open to be viewed. It $accessmsg \\vskip 0 mm "; |
|
} |
|
} |
|
} elsif ($target eq 'web') { |
|
my $name= &get_resource_name($parstack,$safeeval); |
|
if ($status eq 'CAN_ANSWER') { |
|
# create a page header and exit |
|
$result.="$head_tag_start<title>$name</title></head> |
|
$body_tag_start \n $form_tag_start". |
|
'<input type="hidden" name="submitted" value="yes" />'; |
|
if ($ENV{'request.state'} eq "construct") { |
|
$result.= &problem_web_to_edit_header($ENV{'form.rndseed'}); |
|
} |
|
# if we are viewing someone else preserve that info |
|
if (defined $ENV{'form.grade_symb'}) { |
|
foreach my $field ('symb','courseid','domain','username') { |
|
$result .= '<input type="hidden" name="grade_'.$field. |
|
'" value="'.$ENV{"form.grade_$field"}.'" />'."\n"; |
|
} |
|
} |
|
} elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER' |
|
|| $status eq 'CLOSED' || $status eq 'UNAVALAILABLE') { |
|
$result.=$head_tag_start. |
|
"<title>$name</title></head>\n$body_tag_start\n"; |
|
} |
|
} elsif ($target eq 'tex') { |
|
my $startminipage = ''; |
|
if (not $ENV{'form.problem_split'}=~/yes/) { |
|
$startminipage = '\begin{minipage}{\textwidth}'; |
|
} |
|
my $name= &Apache::lonxml::get_param('name',$parstack,$safeeval); |
|
if ($name eq '') { |
|
$name=&Apache::lonnet::EXT('resource.title'); |
|
if ($name eq 'con_lost') { $name = ''; } |
|
} |
|
$Apache::lonhomework::name=$name; |
|
my $id = $Apache::inputtags::part; |
|
my $weight = &Apache::lonnet::EXT("resource.$id.weight"); |
|
my $allkeys=&Apache::lonnet::metadata($ENV{'request.uri'},'keys'); |
|
my @allkeys = split /,/,$allkeys; |
|
my $allow_print_points = 0; |
|
foreach my $partial_key (@allkeys) { |
|
if ($partial_key=~m/weight/) { |
|
$allow_print_points++; |
|
} |
|
} |
|
my $duedate = &Apache::lonnet::EXT("resource.$id.duedate"); |
|
$duedate = POSIX::strftime("%c",localtime($duedate)); |
|
my $temp_file; |
|
my $filename = "/home/httpd/prtspool/$ENV{'user.name'}_$ENV{'user.domain'}_printout.due"; |
|
if (-e $filename) { |
|
$temp_file = Apache::File->new($filename); |
} else { |
} else { |
$result .= '\parbox{\minipagewidth}{\vskip 1mm\textit{Due date: '.$duedate.'} \\\\\\\\'; |
$temp_file = Apache::File->new('>>'.$filename); |
} |
} |
} else { |
my @due_file_content = <$temp_file>; |
if (not $ENV{'request.symb'} =~ m/\.page_/) { |
my $due_file_content = $due_file_content[$#due_file_content]; |
$result .= '\begin{document} \noindent \vskip 1 mm'; |
chomp $due_file_content; |
|
my $name_of_resourse= &get_resource_name($parstack,$safeeval); |
|
if ($due_file_content ne $duedate) { |
|
$temp_file = Apache::File->new('>'.$filename); |
|
print $temp_file "$duedate\n"; |
|
if (not $ENV{'request.symb'} =~ m/\.page_/) { |
|
if(not $duedate=~m/1969/ and $Apache::lonhomework::type ne 'exam') { |
|
$result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent\textit{Due date: '.$duedate.'} \vskip 1 mm\noindent '.$startminipage; |
|
} else { |
|
$result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent \vskip 1 mm \noindent'.$startminipage; |
|
if ($Apache::lonhomework::type eq 'exam' and $allow_print_points==1) { $result .= '\fbox{\textit{'.$weight.' pt}}';} |
|
} |
|
} else { |
|
$result .= '\vskip 1mm\textit{Due date: '.$duedate.'} \\\\\\\\'; |
|
} |
} else { |
} else { |
$result .= '\parbox{\minipagewidth}{\vskip 1mm \\\\\\\\'; |
if (not $ENV{'request.symb'} =~ m/\.page_/) { |
} |
$result .= '\begin{document} \typeout{STAMPOFPASSEDRESOURCESTART Resource <h2>"'.$name_of_resourse.'"</h2> located in <br /><small><b>'.$ENV{'request.uri'}.'</b></small><br /> STAMPOFPASSEDRESOURCEEND} \noindent \vskip 1 mm\noindent'.$startminipage; |
|
if (($Apache::lonhomework::type eq 'exam') and ($allow_print_points==1)) { $result .= '\fbox{\textit{'.$weight.' pt}}';} |
|
} else { |
|
$result .= '\vskip 1mm \\\\\\\\'; |
|
} |
|
} |
} |
} |
|
} elsif ($target eq 'edit') { |
|
$result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start. |
|
&problem_edit_header(); |
|
my $temp=&Apache::edit::insertlist($target,$token); |
|
$result.=$temp; |
|
} elsif ($target eq 'modified') { |
|
$result=$token->[4]; |
|
$result.=&Apache::edit::handle_insert(); |
|
} else { |
|
# page_start returned a starting result, delete it if we don't need it |
|
$result = ''; |
} |
} |
} elsif ($target eq 'edit') { |
return $result; |
$result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start. |
|
&problem_edit_header(); |
|
my $temp=&Apache::edit::insertlist($target,$token); |
|
$result.=$temp; |
|
} elsif ($target eq 'modified') { |
|
$result=$token->[4]; |
|
$result.=&Apache::edit::handle_insert(); |
|
} else { |
|
# page_start returned a starting result, delete it if we don't need it |
|
$result = ''; |
|
} |
|
return $result; |
|
} |
} |
|
|
sub end_problem { |
sub end_problem { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $result=''; |
my $result=''; |
my $status=$Apache::inputtags::status['-1']; |
my $status=$Apache::inputtags::status['-1']; |
if ($target eq 'grade' || $target eq 'web' || $target eq 'answer' || $target eq 'tex') { |
if ($target eq 'grade' || $target eq 'web' || $target eq 'answer' || |
if ( $target eq 'grade' && $Apache::inputtags::part eq '0') { |
$target eq 'tex') { |
# if part is zero, no <part>s existed, so we need to the grading |
if ( $target eq 'grade' && $Apache::inputtags::part eq '0' && |
&Apache::inputtags::grade; |
$status eq 'CAN_ANSWER' ) { |
} elsif ( ($target eq 'web' || $target eq 'tex') && $Apache::inputtags::part eq '0' && |
# if part is zero, no <part>s existed, so we need to the grading |
$status ne 'UNCHECKEDOUT') { |
&Apache::inputtags::grade; |
# if part is zero, no <part>s existed, so we need show the current |
} elsif ( ($target eq 'web' || $target eq 'tex') && |
# grading status |
$Apache::inputtags::part eq '0' && |
my $gradestatus = &Apache::inputtags::gradestatus($Apache::inputtags::part); |
$status ne 'UNCHECKEDOUT') { |
#FIXME this is ugly we should just generate tex in inputtags |
# if part is zero, no <part>s existed, so we need show the current |
if ($target eq 'tex') { $gradestatus=&html_to_tex($gradestatus); } |
# grading status |
$result.= $gradestatus; |
my $gradestatus = &Apache::inputtags::gradestatus($Apache::inputtags::part,$target); |
} |
$result.= $gradestatus; |
if ( |
} |
(($target eq 'web') && ($ENV{'request.state'} ne 'construct')) || |
if ( |
($target eq 'answer') || ($target eq 'tex') |
(($target eq 'web') && ($ENV{'request.state'} ne 'construct')) || |
) { |
($target eq 'answer') || ($target eq 'tex') |
if ($status eq 'CAN_ANSWER') { |
) { |
if ($target ne 'tex') { |
if ($status eq 'CAN_ANSWER') { |
$result.="</form></body>\n"; |
if ($target ne 'tex' && |
} |
$ENV{'form.answer_output_mode'} ne 'tex') { |
} elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER' || |
$result.="</form></body>\n"; |
$status eq 'UNCHECKEDOUT' ) { |
} |
if ($target ne 'tex') { |
} elsif ($status eq 'SHOW_ANSWER' || $status eq 'CANNOT_ANSWER' || |
$result.="</body>\n"; |
$status eq 'UNCHECKEDOUT' ) { |
} |
if ($target ne 'tex' && |
} |
$ENV{'form.answer_output_mode'} ne 'tex') { |
if ($target ne 'tex') { |
$result.="</body>\n"; |
$result.=&Apache::lonxml::xmlend(); |
} |
} else { |
} |
$result .= '\vskip 0.5mm\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}'; |
if ($target eq 'web') { |
if (not $ENV{'request.symb'} =~ m/\.page_/) { |
$result.=&Apache::lonxml::xmlend(); |
$result .= '\end{document} '; |
} elsif ($target eq 'tex') { |
} else { |
my $endminipage = ''; |
$result .= '} '; |
if (not $ENV{'form.problem_split'}=~/yes/) { |
} |
$endminipage = '\end{minipage}'; |
} |
} |
} |
$result .= '\keephidden{ENDOFPROBLEM}\vskip 0.5mm\noindent\makebox[\textwidth/$number_of_columns][b]{\hrulefill}'; |
if ($target eq 'grade') { |
if (not $ENV{'request.symb'} =~ m/\.page_/) { |
&Apache::lonhomework::showhash(%Apache::lonhomework::results); |
$result .= $endminipage.'\end{document} '; |
&finalize_storage(); |
} else { |
} |
$result .= ''; |
} elsif ($target eq 'meta') { |
} |
if ($Apache::inputtags::part eq '0') { |
} |
$result=&Apache::response::mandatory_part_meta; |
} |
} |
if ($target eq 'grade') { |
} elsif ($target eq 'edit') { |
&Apache::lonhomework::showhash(%Apache::lonhomework::results); |
&Apache::lonxml::debug("in end_problem with $target, edit"); |
&finalize_storage(); |
$result = &problem_edit_footer(); |
} |
} |
if ($target eq 'answer' && ($ENV{'request.state'} eq 'construct') |
return $result; |
&& $ENV{'form.answer_output_mode'} ne 'tex') { |
} |
$result.='</html>'; # normally we get it from xmlend, but in CSTR |
|
# we always show answer mode too. |
#FIXME I am ugly shoot me |
} |
sub html_to_tex { |
} elsif ($target eq 'meta') { |
my ($string)=@_; |
if ($Apache::inputtags::part eq '0') { |
$string =~ s/<table>//; |
@Apache::inputtags::response=(); |
$string =~ s/<\/table>//; |
$result=&Apache::response::mandatory_part_meta; |
$string =~ s/<tr([^>]*)>//g; |
} |
$string =~ s/<\/tr>//g; |
} elsif ($target eq 'edit') { |
$string =~ s/<td([^>]*)>//g; |
&Apache::lonxml::debug("in end_problem with $target, edit"); |
$string =~ s/<\/td>//g; |
$result = &problem_edit_footer(); |
$string =~ s/<b>/\\textbf{/g; |
} |
$string =~ s/<\/b>/}/g; |
|
$string =~ s/<br \/>/\\vskip 0 mm /g; |
if ($ENV{'request.state'} eq 'construct' && $target eq 'web') { |
$string =~ s/<input([^>]*)>//g; |
&Apache::inputtags::check_for_duplicate_ids(); |
return $string; |
} |
|
undef(%Apache::lonhomework::history); |
|
undef(%Apache::lonhomework::results); |
|
undef($Apache::inputtags::part); |
|
undef($Apache::lonhomework::parsing_a_problem); |
|
|
|
return $result; |
} |
} |
|
|
|
|
sub start_library { |
sub start_library { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($result,$head_tag_start,$body_tag_start,$form_tag_start); |
my ($result,$head_tag_start,$body_tag_start,$form_tag_start); |
|
|
if ($target eq 'edit') { |
if ($target eq 'edit') { |
($result,$head_tag_start,$body_tag_start,$form_tag_start)= |
($result,$head_tag_start,$body_tag_start,$form_tag_start)= |
&page_start($target,$token,$tagstack,$parstack,$parser,$safeeval); |
&page_start($target,$token,$tagstack,$parstack,$parser,$safeeval); |
$result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start. |
$result.=$head_tag_start."</head>".$body_tag_start.$form_tag_start. |
&problem_edit_header(); |
&problem_edit_header(); |
my $temp=&Apache::edit::insertlist($target,$token); |
my $temp=&Apache::edit::insertlist($target,$token); |
$result.=$temp; |
$result.=$temp; |
} elsif ($target eq 'modified') { |
} elsif ($target eq 'modified') { |
$result=$token->[4]; |
$result=$token->[4]; |
$result.=&Apache::edit::handle_insert(); |
$result.=&Apache::edit::handle_insert(); |
} elsif ($target eq 'web' && $$tagstack[0] ne 'problem' && |
} elsif ($target eq 'web' && $$tagstack[0] ne 'problem' && |
$ENV{'request.state'} eq "construct" ) { |
$ENV{'request.state'} eq "construct" ) { |
($result,$head_tag_start,$body_tag_start,$form_tag_start)= |
($result,$head_tag_start,$body_tag_start,$form_tag_start)= |
&page_start($target,$token,$tagstack,$parstack,$parser,$safeeval); |
&page_start($target,$token,$tagstack,$parstack,$parser,$safeeval); |
my $name=&get_resource_name($parstack,$safeeval); |
my $name=&get_resource_name($parstack,$safeeval); |
my $rndseed=&setup_rndseed($safeeval); |
my $rndseed=&setup_rndseed($safeeval); |
$result.="$head_tag_start<title>$name</title></head> |
$result.="$head_tag_start<title>$name</title></head> |
$body_tag_start \n $form_tag_start". |
$body_tag_start \n $form_tag_start". |
'<input type="hidden" name="submitted" value="yes" />'; |
'<input type="hidden" name="submitted" value="yes" />'; |
$result.=&problem_web_to_edit_header($rndseed); |
$result.=&problem_web_to_edit_header($rndseed); |
} |
} |
return $result; |
return $result; |
} |
} |
|
|
sub end_library { |
sub end_library { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $result=''; |
my $result=''; |
if ($target eq 'edit') { |
if ($target eq 'edit') { |
$result=&problem_edit_footer(); |
$result=&problem_edit_footer(); |
} elsif ($target eq 'web' && $$tagstack[0] ne 'problem' && |
} elsif ($target eq 'web' && $$tagstack[0] ne 'problem' && |
$ENV{'request.state'} eq "construct") { |
$ENV{'request.state'} eq "construct") { |
$result.='</form></body>'.&Apache::lonxml::xmlend(); |
$result.='</form></body>'.&Apache::lonxml::xmlend(); |
} |
} |
return $result; |
return $result; |
|
} |
|
|
|
sub start_definetag { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
|
|
my $result; |
|
|
|
my $name = $token->[2]->{'name'}; |
|
my $skip=&Apache::lonxml::get_all_text("/definetag",$parser); |
|
if ($name=~/^\//) { |
|
$result= |
|
'<br /><table bgcolor="#FFBBBB"><tr><th>END <tt>'.$name.'</tt></th></tr>'; |
|
} else { |
|
$result= |
|
'<br /><table bgcolor="#BBFFBB"><tr><th>BEGIN <tt>'.$name.'</tt></th></tr>'; |
|
} |
|
$skip=~s/\</\<\;/gs; |
|
$skip=~s/\>/\>\;/gs; |
|
$result.='<tr><td><pre>'.$skip.'</pre></td></tr></table>'; |
|
return $result; |
|
} |
|
|
|
sub end_definetag { |
|
return ''; |
} |
} |
|
|
sub start_block { |
sub start_block { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
|
|
my $result; |
|
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
my $code = @$parstack[$#$parstack]; |
$target eq 'tex' || $target eq 'analyze') { |
$code =~ s/\"//g; |
my $code = $token->[2]->{'condition'}; |
$code .=';return $condition;'; |
if ($code) { |
# print "<br />$code<br />"; |
if (!$Apache::lonxml::default_homework_loaded) { |
my $result = &Apache::run::run($code,$safeeval); |
&Apache::lonxml::default_homework_load($safeeval); |
&Apache::lonxml::debug("block :$code: returned :$result:"); |
} |
if ( ! $result ) { |
$result = &Apache::run::run($code,$safeeval); |
my $skip=&Apache::lonxml::get_all_text("/block",$$parser[$#$parser]); |
&Apache::lonxml::debug("block :$code: returned :$result:"); |
&Apache::lonxml::debug("skipping ahead :$skip: $$parser[$#$parser]"); |
} else { |
|
$result='1'; |
|
} |
|
if ( ! $result ) { |
|
my $skip=&Apache::lonxml::get_all_text("/block",$parser); |
|
&Apache::lonxml::debug("skipping ahead :$skip: $$parser[-1]"); |
|
} |
|
$result=''; |
|
} elsif ($target eq 'edit') { |
|
$result .=&Apache::edit::tag_start($target,$token); |
|
$result .=&Apache::edit::text_arg('Test Condition:','condition', |
|
$token,40); |
|
$result .=&Apache::edit::end_row().&Apache::edit::start_spanning_row(); |
|
} elsif ($target eq 'modified') { |
|
my $constructtag=&Apache::edit::get_new_args($token,$parstack, |
|
$safeeval,'condition'); |
|
if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); } |
} |
} |
} |
return $result; |
return ""; |
|
} |
} |
|
|
sub end_block { |
sub end_block { |
return ''; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
my $result; |
|
if ($target eq "edit") { |
|
$result.= &Apache::edit::tag_end($target,$token,''); |
|
} |
|
return $result; |
|
} |
|
|
|
sub start_languageblock { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
|
|
my $result; |
|
|
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
|
$target eq 'tex' || $target eq 'analyze') { |
|
&Apache::lonxml::startredirection(); |
|
} elsif ($target eq 'edit') { |
|
$result .=&Apache::edit::tag_start($target,$token); |
|
$result .=&Apache::edit::text_arg('Include Language:','include', |
|
$token,40); |
|
$result .=&Apache::edit::text_arg('Exclude Language:','exclude', |
|
$token,40); |
|
$result .=&Apache::edit::end_row().&Apache::edit::start_spanning_row(); |
|
} elsif ($target eq 'modified') { |
|
my $constructtag=&Apache::edit::get_new_args($token,$parstack, |
|
$safeeval,'include', |
|
'exclude'); |
|
if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); } |
|
} |
|
return $result; |
|
} |
|
|
|
sub end_languageblock { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
my $result; |
|
|
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
|
$target eq 'tex' || $target eq 'analyze') { |
|
my $text=&Apache::lonxml::endredirection(); |
|
my $include= &Apache::lonxml::get_param('include',$parstack,$safeeval); |
|
my $exclude= &Apache::lonxml::get_param('exclude',$parstack,$safeeval); |
|
my %languages=&Apache::loncommon::display_languages(); |
|
$result='1'; |
|
if ($include) { |
|
$result=''; |
|
foreach (split(/\,/,$include)) { |
|
if ($languages{$_}) { $result='1'; } |
|
} |
|
} |
|
if ($exclude) { |
|
foreach (split(/\,/,$exclude)) { |
|
if ($languages{$_}) { $result='0'; } |
|
} |
|
} |
|
if ( ! $result ) { |
|
$result=''; |
|
} else { |
|
$result=$text; |
|
} |
|
} elsif ($target eq "edit") { |
|
$result.= &Apache::edit::tag_end($target,$token,''); |
|
} |
|
return $result; |
|
} |
|
|
|
sub start_instructorcomment { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
|
|
my $result; |
|
|
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
|
$target eq 'tex' || $target eq 'analyze') { |
|
$result=($ENV{'request.role'}=~/^(in|cc|au|ca|li)/); |
|
if ( ! $result ) { |
|
my $skip=&Apache::lonxml::get_all_text("/instructorcomment",$parser); |
|
&Apache::lonxml::debug("skipping ahead :$skip: $$parser[-1]"); |
|
} |
|
$result=''; |
|
} elsif ($target eq 'edit') { |
|
$result .=&Apache::edit::tag_start($target,$token); |
|
$result .=&Apache::edit::end_row().&Apache::edit::start_spanning_row(); |
|
} |
|
return $result; |
|
} |
|
|
|
sub end_instructorcomment { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
my $result; |
|
if ($target eq "edit") { |
|
$result.= &Apache::edit::tag_end($target,$token,''); |
|
} |
|
return $result; |
} |
} |
|
|
sub start_while { |
sub start_while { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
|
my $code = @$parstack[$#$parstack]; |
my $result; |
$code =~ s/\"//g; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
$code .=';return $condition;'; |
$target eq 'tex' || $target eq 'analyze') { |
|
my $code = $token->[2]->{'condition'}; |
push( @Apache::structuretags::whileconds, $code); |
|
my $result = &Apache::run::run($code,$safeeval); |
push( @Apache::structuretags::whileconds, $code); |
my $bodytext=$$parser[$#$parser]->get_text("/while"); |
if (!$Apache::lonxml::default_homework_loaded) { |
push( @Apache::structuretags::whilebody, $bodytext); |
&Apache::lonxml::default_homework_load($safeeval); |
if ( $result ) { |
} |
&Apache::lonxml::newparser($parser,\$bodytext); |
my $result = &Apache::run::run($code,$safeeval); |
} |
my $bodytext=&Apache::lonxml::get_all_text("/while",$parser); |
return ""; |
push( @Apache::structuretags::whilebody, $bodytext); |
|
push( @Apache::structuretags::whileline, $token->[5]); |
|
&Apache::lonxml::debug("s code $code got -$result-"); |
|
if ( $result ) { |
|
&Apache::lonxml::newparser($parser,\$bodytext); |
|
} |
|
} elsif ($target eq 'edit') { |
|
$result .=&Apache::edit::tag_start($target,$token); |
|
$result .=&Apache::edit::text_arg('Test Condition:','condition', |
|
$token,40); |
|
$result .=&Apache::edit::end_row().&Apache::edit::start_spanning_row(); |
|
} elsif ($target eq 'modified') { |
|
my $constructtag=&Apache::edit::get_new_args($token,$parstack, |
|
$safeeval,'condition'); |
|
if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); } |
|
} |
|
return $result; |
} |
} |
|
|
sub end_while { |
sub end_while { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $code = pop @Apache::structuretags::whileconds; |
my $result; |
my $bodytext = pop @Apache::structuretags::whilebody; |
|
my $result = &Apache::run::run($code,$safeeval); |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
if ( $result ) { |
$target eq 'tex' || $target eq 'analyze') { |
&Apache::lonxml::newparser($parser,\$bodytext); |
my $code = pop(@Apache::structuretags::whileconds); |
} |
my $bodytext = pop(@Apache::structuretags::whilebody); |
return ""; |
my $line = pop(@Apache::structuretags::whileline); |
|
my $return = &Apache::run::run($code,$safeeval); |
|
my $starttime=time; |
|
my $error=0; |
|
while ($return) { |
|
if (time-$starttime > |
|
$Apache::lonnet::perlvar{'lonScriptTimeout'}) { |
|
$return = 0; $error=1; next; |
|
} |
|
$result.=&Apache::scripttag::xmlparse($bodytext); |
|
$return = &Apache::run::run($code,$safeeval); |
|
} |
|
if ($error) { |
|
&Apache::lonxml::error('<pre>Code ran too long. It ran for more than '.$Apache::lonnet::perlvar{'lonScriptTimeout'}.' seconds occured while running <while$gt; on line '.$line.'</pre>'); |
|
} |
|
} elsif ($target eq "edit") { |
|
$result.= &Apache::edit::tag_end($target,$token,''); |
|
} |
|
return $result; |
} |
} |
|
|
# <randomlist show="1"> |
# <randomlist show="1"> |
# <tag1>..</tag1> |
# <tag1>..</tag1> |
# <tag2>..</tag2> |
# <tag2>..</tag2> |
# <tag3>..</tag3> |
# <tag3>..</tag3> |
# ... |
# ... |
# </randomlist> |
# </randomlist> |
sub start_randomlist { |
sub start_randomlist { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $result; |
my $result; |
if ($target eq 'answer' || $target eq 'grade' || $target eq 'web' || |
if ($target eq 'answer' || $target eq 'grade' || $target eq 'web' || |
$target eq 'tex') { |
$target eq 'tex' || $target eq 'analyze') { |
my $body= &Apache::lonxml::get_all_text("/randomlist",$$parser[$#$parser]); |
my $body= &Apache::lonxml::get_all_text("/randomlist",$parser); |
my $b_parser= HTML::TokeParser->new(\$body); |
my $b_parser= HTML::TokeParser->new(\$body); |
my $b_tok; |
my $b_tok; |
my @randomlist; |
my @randomlist; |
my $list_item; |
my $list_item; |
while($b_tok = $b_parser->get_token() ) { |
while($b_tok = $b_parser->get_token() ) { |
if($b_tok->[0] eq 'S') { # start tag |
if($b_tok->[0] eq 'S') { # start tag |
# get content of the tag until matching end tag |
# get content of the tag until matching end tag |
# get all text upto the matching tag |
# get all text upto the matching tag |
# and push the content into @randomlist |
# and push the content into @randomlist |
$list_item = &Apache::lonxml::get_all_text('/'.$b_tok->[1],$b_parser); |
$list_item = &Apache::lonxml::get_all_text('/'.$b_tok->[1], |
$list_item = "$b_tok->[4]"."$list_item"."</$b_tok->[1]>"; |
$b_parser); |
push(@randomlist,$list_item); |
$list_item = "$b_tok->[4]"."$list_item"."</$b_tok->[1]>"; |
# print "<br /><b>START-TAG $b_tok->[1], $b_tok->[4], $list_item</b>"; |
push(@randomlist,$list_item); |
} |
# print "<br /><b>START-TAG $b_tok->[1], $b_tok->[4], |
if($b_tok->[0] eq 'T') { # text |
# $list_item</b>"; |
# what to do with text in between tags? |
} |
# print "<b>TEXT $b_tok->[1]</b><br />"; |
if($b_tok->[0] eq 'T') { # text |
} |
# what to do with text in between tags? |
# if($b_tok->[0] eq 'E') { # end tag, should not happen |
# print "<b>TEXT $b_tok->[1]</b><br />"; |
# print "<b>END-TAG $b_tok->[1]</b><br />"; |
} |
# } |
# if($b_tok->[0] eq 'E') { # end tag, should not happen |
} |
# print "<b>END-TAG $b_tok->[1]</b><br />"; |
my @idx_arr = (0 .. $#randomlist); |
# } |
&Apache::structuretags::shuffle(\@idx_arr); |
} |
my $bodytext = ''; |
my @idx_arr = (0 .. $#randomlist); |
my $show=$#randomlist; |
&Apache::structuretags::shuffle(\@idx_arr); |
my $showarg=&Apache::lonxml::get_param('show',$parstack,$safeeval); |
my $bodytext = ''; |
$showarg--; |
my $show=$#randomlist; |
if ( ($showarg >= 0) && ($showarg < $show) ) { $show = $showarg; } |
my $showarg=&Apache::lonxml::get_param('show',$parstack,$safeeval); |
for(0 .. $show) { |
$showarg--; |
$bodytext .= "$randomlist[ $idx_arr[$_] ]"; |
if ( ($showarg >= 0) && ($showarg < $show) ) { $show = $showarg; } |
} |
for(0 .. $show) { |
&Apache::lonxml::newparser($parser,\$bodytext); |
$bodytext .= "$randomlist[ $idx_arr[$_] ]"; |
} elsif ($target eq 'edit' ) { |
} |
$result .= &Apache::edit::tag_start($target,$token); |
&Apache::lonxml::newparser($parser,\$bodytext); |
$result .= &Apache::edit::text_arg('Maximum Tags to Show:','show',$token,5); |
} elsif ($target eq 'edit' ) { |
$result .= &Apache::edit::end_row().&Apache::edit::start_spanning_row(); |
$result .=&Apache::edit::tag_start($target,$token); |
} elsif ($target eq 'modified' ) { |
$result .=&Apache::edit::text_arg('Maximum Tags to Show:','show', |
my $constructtag=&Apache::edit::get_new_args($token,$parstack,$safeeval, |
$token,5); |
'show'); |
$result .=&Apache::edit::end_row().&Apache::edit::start_spanning_row(); |
if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); } |
} elsif ($target eq 'modified' ) { |
} |
my $constructtag=&Apache::edit::get_new_args($token,$parstack, |
return $result; |
$safeeval,'show'); |
|
if ($constructtag) { $result = &Apache::edit::rebuild_tag($token); } |
|
} |
|
return $result; |
} |
} |
|
|
sub shuffle { |
sub shuffle { |
my $a=shift; |
my $a=shift; |
my $i; |
my $i; |
if (defined(@$a)) { |
if (defined(@$a)) { |
&Apache::response::setrandomnumber(); |
&Apache::response::setrandomnumber(); |
for($i=@$a;--$i;) { |
for($i=@$a;--$i;) { |
my $j=int rand($i+1); |
my $j=int(&Math::Random::random_uniform() * ($i+1)); |
next if $i == $j; |
next if $i == $j; |
@$a[$i,$j] = @$a[$j,$i]; |
@$a[$i,$j] = @$a[$j,$i]; |
} |
} |
} |
} |
} |
} |
|
|
sub end_randomlist { |
sub end_randomlist { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $result; |
my $result; |
if ($target eq 'edit' ) { |
if ($target eq 'edit' ) { |
$result=&Apache::edit::tag_end($target,$token,'End Randomly Parsed Block'); |
$result=&Apache::edit::tag_end($target,$token, |
} |
'End Randomly Parsed Block'); |
return $result; |
} |
|
return $result; |
} |
} |
|
|
sub start_part { |
sub start_part { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $result=''; |
my $result=''; |
my $id= &Apache::lonxml::get_param('id',$parstack,$safeeval); |
my $id= &Apache::lonxml::get_param('id',$parstack,$safeeval); |
if ($id eq '') { $id = $Apache::lonxml::curdepth; } |
if ($id eq '') { $id = $Apache::lonxml::curdepth; } |
$Apache::inputtags::part=$id; |
$Apache::inputtags::part=$id; |
@Apache::inputtags::responselist = (); |
push(@Apache::inputtags::partlist,$id); |
@Apache::inputtags::previous=(); |
@Apache::inputtags::response=(); |
if ($target eq 'meta') { |
@Apache::inputtags::previous=(); |
return &Apache::response::mandatory_part_meta; |
@Apache::inputtags::previous_version=(); |
} elsif ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') { |
$Apache::lonhomework::problemstatus= |
my ($status,$accessmsg) = &Apache::lonhomework::check_access($id); |
&Apache::lonnet::EXT("resource.$id.problemstatus"); |
push (@Apache::inputtags::status,$status); |
my $hidden=&Apache::loncommon::check_if_partid_hidden($Apache::inputtags::part); |
my $expression='$external::datestatus="'.$status.'";'; |
|
$expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.$id.solved"}.'";'; |
if ($target eq 'meta') { |
&Apache::run::run($expression,$safeeval); |
return &Apache::response::mandatory_part_meta; |
if ( $status eq 'CLOSED' ) { |
} elsif ($target eq 'web' || $target eq 'grade' || |
my $bodytext=&Apache::lonxml::get_all_text("/part",$$parser[$#$parser]); |
$target eq 'answer' || $target eq 'tex') { |
if ( $target eq "web" ) { |
if ($hidden) { |
$result="<br />Part is not open to be viewed. It $accessmsg<br />"; |
my $bodytext=&Apache::lonxml::get_all_text("/part",$parser); |
} elsif ( $target eq 'tex' ) { |
} else { |
$result="\\vskip 0 mm Part is not open to be viewed. It $accessmsg \\\\"; |
my ($status,$accessmsg) = &Apache::lonhomework::check_access($id); |
} |
push (@Apache::inputtags::status,$status); |
} else { |
my $expression='$external::datestatus="'.$status.'";'; |
if ($target eq 'tex') { |
$expression.='$external::gradestatus="'.$Apache::lonhomework::history{"resource.$id.solved"}.'";'; |
$result='\vskip 0 mm'; |
&Apache::run::run($expression,$safeeval); |
} |
if ( $status eq 'CLOSED' ) { |
|
my $bodytext=&Apache::lonxml::get_all_text("/part",$parser); |
|
if ( $target eq "web" ) { |
|
$result="<br />Part is not open to be viewed. It $accessmsg<br />"; |
|
} elsif ( $target eq 'tex' ) { |
|
if (not $ENV{'form.problem_split'}=~/yes/) { |
|
$result="\\end{minipage}\\vskip 0 mm Part is not open to be viewed. It $accessmsg \\\\\\begin{minipage}{\\textwidth}"; |
|
} else { |
|
$result="\\vskip 0 mm Part is not open to be viewed. It $accessmsg \\\\"; |
|
} |
|
} |
|
} else { |
|
if ($target eq 'tex') { |
|
if (not $ENV{'form.problem_split'}=~/yes/) { |
|
$result.='\noindent \end{minipage}\vskip 0 mm \noindent \begin{minipage}{\textwidth}\noindent'; |
|
} |
|
my $weight = &Apache::lonnet::EXT("resource.$id.weight"); |
|
if ($Apache::lonhomework::type eq 'exam') { $result .= '\fbox{\textit{'.$weight.' pt}}';} |
|
} |
|
} |
|
} |
|
} elsif ($target eq 'edit') { |
|
$result.=&Apache::edit::tag_start($target,$token); |
|
$result.=&Apache::edit::text_arg('Part ID:','id',$token). |
|
&Apache::loncommon::help_open_topic("Part_Tag_Edit_Help"). |
|
&Apache::edit::end_row().&Apache::edit::start_spanning_row(); |
|
} elsif ($target eq 'modified') { |
|
my $constructtag=&Apache::edit::get_new_args($token,$parstack, |
|
$safeeval,'id'); |
|
if ($constructtag) { |
|
$result = &Apache::edit::rebuild_tag($token); |
|
$result.=&Apache::edit::handle_insert(); |
|
} |
} |
} |
} |
return $result; |
return $result; |
|
} |
} |
|
|
sub end_part { |
sub end_part { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
&Apache::lonxml::debug("in end_part $target "); |
&Apache::lonxml::debug("in end_part $target "); |
my $status=$Apache::inputtags::status['-1']; |
my $status=$Apache::inputtags::status['-1']; |
pop @Apache::inputtags::status; |
my $hidden=&Apache::loncommon::check_if_partid_hidden($Apache::inputtags::part); |
if ( $target eq 'meta' ) { return ''; } |
my $result=''; |
if ( $target eq 'grade' && $status eq 'CAN_ANSWER') { |
if ( $target eq 'meta' ) { |
return &Apache::inputtags::grade; |
$result=''; |
} |
} elsif ( $target eq 'grade' && $status eq 'CAN_ANSWER' && !$hidden) { |
if ($target eq 'web' || $target eq 'tex' ) { |
$result=&Apache::inputtags::grade; |
my $gradestatus=&Apache::inputtags::gradestatus($Apache::inputtags::part); |
} elsif (($target eq 'web' || $target eq 'tex') && !$hidden ) { |
#FIXME this is ugly we should just generate tex in inputtags |
my $gradestatus=&Apache::inputtags::gradestatus($Apache::inputtags::part, |
if ($target eq 'tex') { $gradestatus=&html_to_tex($gradestatus); } |
$target); |
return $gradestatus; |
if ($Apache::lonhomework::type eq 'exam') {$gradestatus='';} |
} |
$result=$gradestatus; |
return ''; |
} elsif ($target eq 'edit') { |
|
$result=&Apache::edit::end_table(); |
|
} |
|
pop @Apache::inputtags::status; |
|
$Apache::inputtags::part=''; |
|
return $result; |
} |
} |
|
|
sub start_preduedate { |
sub start_preduedate { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') { |
if ($Apache::inputtags::status['-1'] ne 'CAN_ANSWER' && |
if ($Apache::inputtags::status['-1'] ne 'CAN_ANSWER' && |
$Apache::inputtags::status['-1'] ne 'CANNOT_ANSWER' ) { |
$Apache::inputtags::status['-1'] ne 'CANNOT_ANSWER' && |
&Apache::lonxml::get_all_text("/preduedate",$$parser[$#$parser]); |
$Apache::inputtags::status['-1'] ne 'SHOW_ANSWER') { |
|
&Apache::lonxml::get_all_text("/preduedate",$parser); |
|
} |
} |
} |
} |
return ''; |
return ''; |
|
} |
} |
|
|
sub end_preduedate { |
sub end_preduedate { |
return ''; |
return ''; |
} |
} |
|
|
sub start_postanswerdate { |
sub start_postanswerdate { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'tex') { |
if ($Apache::inputtags::status['-1'] ne 'SHOW_ANSWER') { |
if ($Apache::inputtags::status['-1'] ne 'SHOW_ANSWER') { |
&Apache::lonxml::get_all_text("/postanswerdate",$$parser[$#$parser]); |
&Apache::lonxml::get_all_text("/postanswerdate",$parser); |
} |
} |
} elsif ($target eq 'tex') { |
} elsif ($target eq 'tex') { |
return '\vskip 0 mm \noindent'; |
return '\vskip 0 mm \noindent'; |
} |
} |
return ''; |
return ''; |
} |
} |
|
|
sub end_postanswerdate { |
sub end_postanswerdate { |
return ''; |
return ''; |
} |
} |
|
|
sub start_notsolved { |
sub start_notsolved { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"}; |
$target eq 'tex') { |
&Apache::lonxml::debug("not solved has :$gradestatus:"); |
my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"}; |
if ($gradestatus =~ /^correct/) { |
&Apache::lonxml::debug("not solved has :$gradestatus:"); |
&Apache::lonxml::debug("skipping"); |
if ($gradestatus =~ /^correct/) { |
&Apache::lonxml::get_all_text("/notsolved",$$parser[$#$parser]); |
&Apache::lonxml::debug("skipping"); |
|
&Apache::lonxml::get_all_text("/notsolved",$parser); |
|
} |
} |
} |
} |
return ''; |
return ''; |
|
} |
} |
|
|
sub end_notsolved { |
sub end_notsolved { |
return ''; |
return ''; |
} |
} |
|
|
sub start_solved { |
sub start_solved { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || $target eq 'tex') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer' || |
my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"}; |
$target eq 'tex') { |
if ($gradestatus !~ /^correct/) { |
my $gradestatus=$Apache::lonhomework::history{"resource.$Apache::inputtags::part.solved"}; |
&Apache::lonxml::get_all_text("/solved",$$parser[$#$parser]); |
if ($gradestatus !~ /^correct/) { |
|
&Apache::lonxml::get_all_text("/solved",$parser); |
|
} |
} |
} |
} |
return ''; |
return ''; |
|
} |
} |
|
|
sub end_solved { |
sub end_solved { |
return ''; |
return ''; |
} |
} |
|
|
sub start_startouttext { |
sub start_startouttext { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my @result=(''.''); |
my @result=(''.''); |
if ($target eq 'edit' || $target eq 'modified' ) { @result=('','no'); } |
if ($target eq 'edit' || $target eq 'modified' ) { @result=('','no'); } |
return (@result); |
return (@result); |
} |
} |
|
|
sub end_startouttext { |
sub end_startouttext { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $result=''; |
my $result=''; |
my $text=''; |
my $text=''; |
|
|
if ($target eq 'edit') { |
if ($target eq 'edit') { |
$text=&Apache::lonxml::get_all_text("endouttext",$$parser[-1]); |
$text=&Apache::lonxml::get_all_text("endouttext",$parser); |
$result.=&Apache::edit::start_table($token)."<tr><td>Text Block</td> |
$result.=&Apache::edit::start_table($token)."<tr><td>Text Block</td> |
<td>Delete:". |
<td>Delete:". |
&Apache::edit::deletelist($target,$token) |
&Apache::edit::deletelist($target,$token) |
."</td> |
."</td> |
<td>". |
<td>". |
&Apache::edit::insertlist($target,$token). |
&Apache::edit::insertlist($target,$token). |
&Apache::edit::end_row().&Apache::edit::start_spanning_row()."\n". |
&Apache::edit::end_row(). |
&Apache::edit::editfield($token->[1],$text,"",50,4); |
&Apache::edit::start_spanning_row()."\n" |
} |
. &Apache::loncommon::helpLatexCheatsheet () . |
if ($target eq 'modified') { |
&Apache::edit::editfield($token->[1],$text,"",80,4); |
$text=&Apache::lonxml::get_all_text("endouttext",$$parser['-1']); |
} |
$result='<startouttext />'.&Apache::edit::modifiedfield(); |
if ($target eq 'modified') { |
} |
$text=&Apache::lonxml::get_all_text("endouttext",$parser); |
if ($target eq 'tex') { |
$result='<startouttext />'.&Apache::edit::modifiedfield(); |
$result .= '\noindent '; |
} |
} |
if ($target eq 'tex') { |
return $result; |
$result .= '\noindent '; |
|
} |
|
return $result; |
} |
} |
|
|
sub start_endouttext { |
sub start_endouttext { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my $result=''; |
my $result=''; |
if ($target eq "edit" ) { $result="</td></tr>".&Apache::edit::end_table()."\n"; } |
if ($target eq "edit" ) { $result="</td></tr>".&Apache::edit::end_table()."\n"; } |
if ($target eq "modified") { $result='<endouttext />'; } |
if ($target eq "modified") { |
return $result; |
$result='<endouttext />'. |
|
&Apache::edit::handle_insertafter('startouttext'); } |
|
return $result; |
} |
} |
|
|
sub end_endouttext { |
sub end_endouttext { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my @result=('',''); |
my @result=('',''); |
if ($target eq "edit" || $target eq 'modified') { @result=('','no'); } |
if ($target eq "edit" || $target eq 'modified') { @result=('','no'); } |
return (@result); |
return (@result); |
} |
} |
|
|
sub delete_startouttext { |
sub delete_startouttext { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
# my $text=&Apache::lonxml::get_all_text("endouttext",$$parser['-1']); |
# my $text=&Apache::lonxml::get_all_text("endouttext",$parser); |
my $text=$$parser['-1']->get_text("/endouttext"); |
my $text=$$parser['-1']->get_text("/endouttext"); |
my $ntoken=$$parser['-1']->get_token(); |
my $ntoken=$$parser['-1']->get_token(); |
&Apache::lonxml::debug("Deleting :$text: and :$ntoken->[0]:$ntoken->[1]:$ntoken->[2]: for startouttext"); |
&Apache::lonxml::debug("Deleting :$text: and :$ntoken->[0]:$ntoken->[1]:$ntoken->[2]: for startouttext"); |
&Apache::lonxml::end_tag($tagstack,$parstack,$ntoken); |
&Apache::lonxml::end_tag($tagstack,$parstack,$ntoken); |
# Deleting 2 parallel tag pairs, but we need the numbers later to look like |
# Deleting 2 parallel tag pairs, but we need the numbers later to look like |
# they did the last time round |
# they did the last time round |
&Apache::lonxml::increasedepth($ntoken); |
&Apache::lonxml::increasedepth($ntoken); |
&Apache::lonxml::decreasedepth($ntoken); |
&Apache::lonxml::decreasedepth($ntoken); |
return 1; |
return 1; |
|
} |
|
|
|
sub start_simpleeditbutton { |
|
my ($target,$token,$tagstack,$parstack,$parser,$safeeval)=@_; |
|
my $result=''; |
|
if (($target eq 'web') && |
|
(&Apache::lonnet::allowed('srm',$ENV{'request.course.id'}))) { |
|
my $url=$ENV{'REQUEST_URI'}; |
|
$url=~s/\?.*$//; |
|
$result='<table width="100%" bgcolor="#FFFFAA" border="2"><tr><td>'. |
|
'<a href="'.$url.'/smpedit">Simple Problem Editor</a> - Note: it can take up to 10 minutes for changes to take effect for all users.'. |
|
&Apache::loncommon::help_open_topic('Caching').'</td></tr></table><br />'; |
|
} |
|
return $result; |
|
} |
|
|
|
sub end_simpleeditbutton { |
|
return ''; |
} |
} |
|
|
1; |
1; |