version 1.48, 2001/07/30 22:24:56
|
version 1.53, 2001/10/05 22:29:10
|
Line 1
|
Line 1
|
# The LearningOnline Network with CAPA |
# The LearningOnline Network with CAPA |
# <script> definiton |
# <script> definiton |
# 2/21 Guy |
# 2/21 Guy |
|
# 8/20 Gerd Kortemeyer |
|
|
package Apache::scripttag; |
package Apache::scripttag; |
|
|
Line 30 sub start_script {
|
Line 31 sub start_script {
|
my $bodytext=&Apache::lonxml::get_all_text("/script",$$parser[$#$parser]); |
my $bodytext=&Apache::lonxml::get_all_text("/script",$$parser[$#$parser]); |
if ( $target eq "modified" ) { |
if ( $target eq "modified" ) { |
$result=$token->[4].&Apache::edit::modifiedfield(); |
$result=$token->[4].&Apache::edit::modifiedfield(); |
} elsif ( $target eq "web" || $target eq "grade" ) { |
} elsif ( $target eq "web" || $target eq "grade" || $target eq 'answer') { |
&Apache::run::run($bodytext,$safeeval); |
&Apache::run::run($bodytext,$safeeval); |
|
if (($ENV{'request.state'} eq 'construct') && ($target eq 'web')) { |
|
$Apache::lonxml::evaluate--; |
|
$result.="<a href=\"javascript:newWindow=open(\'\',\'new_W\',\'width=500,height=200,scrollbars=1\');newWindow.document.open(\'text/html\',\'replace\');newWindow.document.writeln(\'<html><head><title>newwindow</title></head><body bgcolor="#FFFFFF"><pre>"; |
|
my $listing= &Apache::run::dump($target,$safeeval); |
|
$listing =~ s/\n/\\n/g; |
|
$result.=$listing; |
|
$result.= "</pre></body></html>\');newWindow.document.close();void(0);\">Script Vars</a>"; |
|
} |
} elsif ($target eq "edit" ) { |
} elsif ($target eq "edit" ) { |
#&Apache::run::run($bodytext,$safeeval); |
#&Apache::run::run($bodytext,$safeeval); |
#$result="<br /> <$token->[1]> output: <br />$bodytext<br />Source:<br />"; |
#$result="<br /> <$token->[1]> output: <br />$bodytext<br />Source:<br />"; |
Line 50 sub end_script {
|
Line 59 sub end_script {
|
my $type = &Apache::lonxml::get_param('type',$parstack,$safeeval); |
my $type = &Apache::lonxml::get_param('type',$parstack,$safeeval); |
my $result=''; |
my $result=''; |
#other script blocks need to survive |
#other script blocks need to survive |
if ($type ne "loncapa/perl") { return $token->[2]; } |
if ($type ne "loncapa/perl") { |
if ($target eq 'edit' ) { return &Apache::edit::end_table(); } |
return $token->[2]; |
|
} elsif ($target eq 'edit' ) { |
|
return &Apache::edit::end_table(); |
|
} elsif (($ENV{'request.state'} eq 'construct') && ($target eq 'web')) { |
|
$Apache::lonxml::evaluate++; |
|
} |
return ''; |
return ''; |
} |
} |
|
|
Line 63 sub start_display {
|
Line 77 sub start_display {
|
|
|
if ( $target eq "modified" ) { |
if ( $target eq "modified" ) { |
$result=$token->[4].&Apache::edit::modifiedfield(); |
$result=$token->[4].&Apache::edit::modifiedfield(); |
} elsif ( $target eq "web" || $target eq "grade" ) { |
} elsif ( $target eq "web" || $target eq "grade" || $target eq 'answer') { |
$result=&Apache::run::run($bodytext,$safeeval); |
$result=&Apache::run::run($bodytext,$safeeval); |
if ($target eq 'grade' ) { |
if ($target eq 'grade' ) { |
$result=''; # grade should produce no output |
$result=''; # grade should produce no output |
Line 90 sub start_scriptlib {
|
Line 104 sub start_scriptlib {
|
my $result =''; |
my $result =''; |
my $error=''; |
my $error=''; |
|
|
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit' || $target eq 'answer') { |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$$parstack[$#$parstack]); |
$$parstack[$#$parstack]); |
Line 110 sub start_scriptlib {
|
Line 124 sub start_scriptlib {
|
} |
} |
if ($target eq "edit" ) { |
if ($target eq "edit" ) { |
$result= |
$result= |
&Apache::edit::tag_start($target,$token). |
&Apache::edit::tag_start($target,$token,'New Script Functions'). |
&Apache::edit::editfield($token->[1],$bodytext,'New Script Functions',40,1). |
&Apache::edit::editfield($token->[1],$bodytext,'',40,1). |
$error; |
$error.'</td></tr>'. |
|
&Apache::edit::end_table(); |
} |
} |
if ($target eq "modified" ) { |
if ($target eq "modified" ) { |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
$bodytext=$$parser[$#$parser]->get_text("/scriptlib"); |
Line 124 sub start_scriptlib {
|
Line 139 sub start_scriptlib {
|
|
|
sub end_scriptlib { |
sub end_scriptlib { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result=''; |
my @result; |
# if ($target eq "edit" ) { $result=" "; } |
if ($target eq "edit" ) { $result[1]='no'; } |
return $result; |
return @result; |
} |
} |
|
|
sub start_parserlib { |
sub start_parserlib { |
Line 134 sub start_parserlib {
|
Line 149 sub start_parserlib {
|
my $bodytext; |
my $bodytext; |
my $result =""; |
my $result =""; |
my $error=''; |
my $error=''; |
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'meta' || $target eq 'edit' || $target eq 'answer') { |
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$bodytext=&Apache::run::evaluate($bodytext,$safeeval, |
$$parstack[$#$parstack]); |
$$parstack[$#$parstack]); |
Line 154 sub start_parserlib {
|
Line 169 sub start_parserlib {
|
} |
} |
if ($target eq "edit" ) { |
if ($target eq "edit" ) { |
$result= |
$result= |
&Apache::edit::tag_start($target,$token). |
&Apache::edit::tag_start($target,$token,'New Tag Definitions'). |
&Apache::edit::editfield($token->[1],$bodytext,"New Tag Definitions",40,1). |
&Apache::edit::editfield($token->[1],$bodytext,'',40,1). |
$error; |
$error.'</td></tr>'. |
|
&Apache::edit::end_table(); |
} |
} |
if ($target eq "modified" ) { |
if ($target eq "modified" ) { |
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
$bodytext=$$parser[$#$parser]->get_text("/parserlib"); |
Line 168 sub start_parserlib {
|
Line 184 sub start_parserlib {
|
|
|
sub end_parserlib { |
sub end_parserlib { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $result=''; |
my @result; |
# if ($target eq "edit" ) { |
if ($target eq "edit" ) { $result[1]='no'; } |
# $result=&Apache::edit::tag_end($target,$token); |
return @result; |
# } |
|
return $result; |
|
} |
} |
|
|
sub start_window { |
sub start_window { |
Line 208 sub start_import {
|
Line 222 sub start_import {
|
|
|
$bodytext=Apache::run::evaluate($bodytext,$safeeval,$$parstack[$#$parstack]); |
$bodytext=Apache::run::evaluate($bodytext,$safeeval,$$parstack[$#$parstack]); |
|
|
if ($target eq 'web' || $target eq 'grade') { |
if ($target eq 'web' || $target eq 'grade' || $target eq 'answer') { |
# FIXME this probably needs to be smart about construction vs. |
# FIXME this probably needs to be smart about construction vs. |
# non construction space. |
# non construction space. |
my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
Line 254 sub end_storetc {
|
Line 268 sub end_storetc {
|
my $result; |
my $result; |
my $output=&Apache::lonxml::endredirection; |
my $output=&Apache::lonxml::endredirection; |
$output =~ s/\"/\"\;/g; |
$output =~ s/\"/\"\;/g; |
$result = "{\bf $output.}}\write\tcfile{\protect\tcpc{ $output.}{\the\value{relpage}}}"; |
$result = '{\bf '.$output.'.}}\write\tcfile{\protect\tcpc{ '.$output.'.}{\the\value{relpage}}}'; |
return $result; |
return $result; |
} |
} |
|
|
|
|
sub start_physnet { |
sub start_physnet { |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my ($target,$token,$tagstack,$parstack,$parser,$safeeval,$style)=@_; |
my $bodytext = '/msu/physnet/cbi.sty'; |
my $bodytext = '/adm/includes/physnet.sty'; |
my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
my $location=&Apache::lonnet::filelocation($Apache::lonxml::pwd['-1'],$bodytext); |
my $cbistyletext=&Apache::lonnet::getfile($location); |
my $cbistyletext=&Apache::lonnet::getfile($location); |
|
|