version 1.312, 2009/06/09 16:33:55
|
version 1.327, 2011/07/04 13:01:57
|
Line 47 use Apache::externalresponse();
|
Line 47 use Apache::externalresponse();
|
use Apache::rankresponse(); |
use Apache::rankresponse(); |
use Apache::matchresponse(); |
use Apache::matchresponse(); |
use Apache::chemresponse(); |
use Apache::chemresponse(); |
|
use Apache::functionplotresponse(); |
use Apache::drawimage(); |
use Apache::drawimage(); |
use Apache::Constants qw(:common); |
use Apache::Constants qw(:common); |
use Apache::loncommon(); |
use Apache::loncommon(); |
Line 111 sub get_target {
|
Line 112 sub get_target {
|
} elsif ( $env{'form.grade_target'} eq 'webgrade' |
} elsif ( $env{'form.grade_target'} eq 'webgrade' |
&& ($Apache::lonhomework::queuegrade eq 'F' )) { |
&& ($Apache::lonhomework::queuegrade eq 'F' )) { |
return ($env{'form.grade_target'}); |
return ($env{'form.grade_target'}); |
} |
} elsif ($env{'form.grade_target'} eq 'answer') { |
|
if ($env{'form.answer_output_mode'} eq 'tex') { |
|
return ($env{'form.grade_target'}); |
|
} |
|
} |
if ($env{'form.webgrade'} && |
if ($env{'form.webgrade'} && |
($Apache::lonhomework::modifygrades eq 'F' |
($Apache::lonhomework::modifygrades eq 'F' |
|| $Apache::lonhomework::queuegrade eq 'F' )) { |
|| $Apache::lonhomework::queuegrade eq 'F' )) { |
Line 124 sub get_target {
|
Line 129 sub get_target {
|
return ('web'); |
return ('web'); |
} |
} |
} elsif ($env{'request.state'} eq "construct") { |
} elsif ($env{'request.state'} eq "construct") { |
|
# |
|
# We are in construction space, editing and testing problems |
|
# |
if ( defined($env{'form.grade_target'}) ) { |
if ( defined($env{'form.grade_target'}) ) { |
return ($env{'form.grade_target'}); |
return ($env{'form.grade_target'}); |
} |
} |
if ( defined($env{'form.preview'})) { |
if ( defined($env{'form.preview'})) { |
if ( defined($env{'form.submitted'})) { |
if ( defined($env{'form.submitted'})) { |
|
# |
|
# We are doing a problem preview |
|
# |
return ('grade', 'web'); |
return ('grade', 'web'); |
} else { |
} else { |
return ('web'); |
return ('web'); |
} |
} |
} else { |
} else { |
if ($env{'form.problemstate'} eq 'WEB_GRADE') { |
if ($env{'form.problemstate'} eq 'WEB_GRADE') { |
#$env{'form.webgrade'} = 'yes'; |
|
return ('grade','webgrade','answer'); |
return ('grade','webgrade','answer'); |
} elsif (($env{'form.problemmode'} eq 'view') || |
} elsif ($env{'form.problemmode'} eq 'view') { |
($env{'form.problemmode'} eq 'discard')) { |
return ('grade','web','answer'); |
if ( defined($env{'form.submitted'}) && |
} elsif ($env{'form.problemmode'} eq 'saveview') { |
(!defined($env{'form.resetdata'})) && |
return ('modified','web','answer'); |
(!defined($env{'form.newrandomization'}))) { |
} elsif ($env{'form.problemmode'} eq 'discard') { |
return ('grade', 'web','answer'); |
return ('web','answer'); |
} else { |
} elsif (($env{'form.problemmode'} eq 'saveedit') || |
return ('web','answer'); |
($env{'form.problemmode'} eq 'undo')) { |
} |
return ('modified','no_output_web','edit'); |
} elsif ($env{'form.problemmode'} eq 'edit') { |
} elsif ($env{'form.problemmode'} eq 'edit') { |
if ( $env{'form.submitted'} eq 'edit' ) { |
return ('no_output_web','edit'); |
if ( $env{'form.submitbutton'} eq &mt('Save and View') ) { |
|
return ('modified','web','answer'); |
|
} else { |
|
return ('modified','no_output_web','edit'); |
|
} |
|
} else { |
|
return ('no_output_web','edit'); |
|
} |
|
} else { |
} else { |
return ('web'); |
return ('web'); |
} |
} |
} |
} |
|
# |
|
# End of Construction Space |
|
# |
} |
} |
|
# |
|
# Huh? We are nowhere, so do nothing. |
|
# |
return (); |
return (); |
} |
} |
|
|
Line 170 sub setup_vars {
|
Line 178 sub setup_vars {
|
# return ';$external::target='.$target.';'; |
# return ';$external::target='.$target.';'; |
} |
} |
|
|
sub createmenu { |
|
my ($which,$request)=@_; |
|
if ($which eq 'grade') { |
|
$request->print('<script type="text/javascript" language="JavaScript"> |
|
hwkmenu=window.open("/res/adm/pages/homeworkmenu.html","homeworkremote", |
|
"height=350,width=150,menubar=no"); |
|
</script>'); |
|
} |
|
} |
|
|
|
sub proctor_checked_in { |
sub proctor_checked_in { |
my ($slot_name,$slot,$type)=@_; |
my ($slot_name,$slot,$type)=@_; |
my @possible_proctors=split(",",$slot->{'proctor'}); |
my @possible_proctors=split(",",$slot->{'proctor'}); |
Line 265 sub check_slot_access {
|
Line 263 sub check_slot_access {
|
} |
} |
if ($slotstatus eq 'NEEDS_CHECKIN' && |
if ($slotstatus eq 'NEEDS_CHECKIN' && |
&proctor_checked_in($slot_name,$returned_slot,$type)) { |
&proctor_checked_in($slot_name,$returned_slot,$type)) { |
&Apache::lonxml::debug("protoctor checked in"); |
&Apache::lonxml::debug("proctor checked in"); |
$slotstatus='CAN_ANSWER'; |
$slotstatus=$status; |
} |
} |
|
|
my ($is_correct,$got_grade,$checkedin); |
my ($is_correct,$got_grade,$checkedin); |
Line 378 sub check_access {
|
Line 376 sub check_access {
|
$date=&mt("can not be accessed from your location."); |
$date=&mt("can not be accessed from your location."); |
return($status,$date); |
return($status,$date); |
} |
} |
|
if ($env{'form.grade_imsexport'}) { |
|
if (($env{'request.course.id'}) && |
|
(&Apache::lonnet::allowed('mdc',$env{'request.course.id'}))) { |
|
return ('SHOW_ANSWER'); |
|
} |
|
} |
foreach my $temp ("opendate","duedate","answerdate") { |
foreach my $temp ("opendate","duedate","answerdate") { |
$lastdate = $date; |
$lastdate = $date; |
if ($temp eq 'duedate') { |
if ($temp eq 'duedate') { |
Line 436 sub check_access {
|
Line 439 sub check_access {
|
if ( $tries eq '' ) { $tries = '0'; } |
if ( $tries eq '' ) { $tries = '0'; } |
if ( $maxtries eq '' && |
if ( $maxtries eq '' && |
$env{'request.state'} ne 'construct') { $maxtries = '2'; } |
$env{'request.state'} ne 'construct') { $maxtries = '2'; } |
|
$Apache::lonhomework::results{'resource.'.$id.'.maxtries'}=$maxtries; |
if ($maxtries && $tries >= $maxtries) { $status = 'CANNOT_ANSWER'; } |
if ($maxtries && $tries >= $maxtries) { $status = 'CANNOT_ANSWER'; } |
# if (correct and show prob status) or excused then CANNOT_ANSWER |
# if (correct and show prob status) or excused then CANNOT_ANSWER |
if(($Apache::lonhomework::history{"resource.$id.solved"}=~/^correct/ |
if(($Apache::lonhomework::history{"resource.$id.solved"}=~/^correct/ |
&& |
&& |
&show_problem_status()) |
&show_problem_status() |
|
&& |
|
$Apache::lonhomework::history{"resource.$id.awarded"}==1) |
|| |
|| |
$Apache::lonhomework::history{"resource.$id.solved"}=~/^excused/) { |
$Apache::lonhomework::history{"resource.$id.solved"}=~/^excused/) { |
$status = 'CANNOT_ANSWER'; |
$status = 'CANNOT_ANSWER'; |
Line 633 sub setupheader {
|
Line 639 sub setupheader {
|
|
|
sub handle_save_or_undo { |
sub handle_save_or_undo { |
my ($request,$problem,$result) = @_; |
my ($request,$problem,$result) = @_; |
|
|
my $file = &Apache::lonnet::filelocation("",$request->uri); |
my $file = &Apache::lonnet::filelocation("",$request->uri); |
my $filebak =$file.".bak"; |
my $filebak =$file.".bak"; |
my $filetmp =$file.".tmp"; |
my $filetmp =$file.".tmp"; |
my $error=0; |
my $error=0; |
if ($env{'form.Undo'} eq &mt('undo')) { |
if (($env{'form.problemmode'} eq 'undo') || ($env{'form.problemmode'} eq 'undoxml')) { |
my $error=0; |
my $error=0; |
if (!&File::Copy::copy($file,$filetmp)) { $error=1; } |
if (!&File::Copy::copy($file,$filetmp)) { $error=1; } |
if ((!$error) && (!&File::Copy::copy($filebak,$file))) { $error=1; } |
if ((!$error) && (!&File::Copy::copy($filebak,$file))) { $error=1; } |
Line 660 sub handle_save_or_undo {
|
Line 667 sub handle_save_or_undo {
|
} |
} |
} else { |
} else { |
&Apache::lonnet::correct_line_ends($result); |
&Apache::lonnet::correct_line_ends($result); |
|
|
my $fs=Apache::File->new(">$filebak"); |
my $fs=Apache::File->new(">$filebak"); |
if (defined($fs)) { |
if (defined($fs)) { |
print $fs $$problem; |
print $fs $$problem; |
Line 715 sub analyze_header {
|
Line 723 sub analyze_header {
|
'onclick="javascript:setmode(this.form,'."'editxml'".')" /> |
'onclick="javascript:setmode(this.form,'."'editxml'".')" /> |
<input type="button" name="submitmode" value="'.&mt('Edit').'" '. |
<input type="button" name="submitmode" value="'.&mt('Edit').'" '. |
'onclick="javascript:setmode(this.form,'."'edit'".')" /> |
'onclick="javascript:setmode(this.form,'."'edit'".')" /> |
<hr class="LC_edit_problem_divide" /> |
<hr /> |
<input type="button" name="submitmode" value="'.&mt("View").'" '. |
<input type="button" name="submitmode" value="'.&mt("View").'" '. |
'onclick="javascript:setmode(this.form,'."'view'".')" /> |
'onclick="javascript:setmode(this.form,'."'view'".')" /> |
<hr class="LC_edit_problem_divide" /> |
<hr /> |
</div> |
</div> |
</form>'; |
</form>'; |
&Apache::lonxml::add_messages(\$result); |
&Apache::lonxml::add_messages(\$result); |
Line 792 sub analyze {
|
Line 800 sub analyze {
|
} |
} |
&Apache::lonhtmlcommon::Update_PrgWin($request,\%prog_state, |
&Apache::lonhtmlcommon::Update_PrgWin($request,\%prog_state, |
&mt('Analyzing Results')); |
&mt('Analyzing Results')); |
$request->print('<hr class="LC_edit_problem_divide" />' |
$request->print('<hr />' |
.'<h3>' |
.'<h3>' |
.&mt('List of possible answers') |
.&mt('List of possible answers') |
.'</h3>' |
.'</h3>' |
Line 903 sub editxmlmode {
|
Line 911 sub editxmlmode {
|
|
|
$problem=''; |
$problem=''; |
} |
} |
if (defined($env{'form.editxmltext'}) || defined($env{'form.Undo'})) { |
|
|
if (($env{'form.problemmode'} eq 'saveeditxml') || |
|
($env{'form.problemmode'} eq 'saveviewxml') || |
|
($env{'form.problemmode'} eq 'undoxml')) { |
my $error=&handle_save_or_undo($request,\$problem, |
my $error=&handle_save_or_undo($request,\$problem, |
\$env{'form.editxmltext'}); |
\$env{'form.editxmltext'}); |
if (!$error) { $problem=&Apache::lonnet::getfile($file); } |
if (!$error) { $problem=&Apache::lonnet::getfile($file); } |
} |
} |
&Apache::lonhomework::showhashsubset(\%env,'^form'); |
&Apache::lonhomework::showhashsubset(\%env,'^form'); |
if ( $env{'form.submitbutton'} eq &mt('Save and View') ) { |
if ($env{'form.problemmode'} eq 'saveviewxml') { |
&Apache::lonhomework::showhashsubset(\%env,'^form'); |
&Apache::lonhomework::showhashsubset(\%env,'^form'); |
$env{'form.problemmode'}='view'; |
$env{'form.problemmode'}='view'; |
&renderpage($request,$file); |
&renderpage($request,$file); |
Line 923 sub editxmlmode {
|
Line 934 sub editxmlmode {
|
&Apache::loncommon::resize_textarea_js(). |
&Apache::loncommon::resize_textarea_js(). |
&Apache::structuretags::setmode_javascript(). |
&Apache::structuretags::setmode_javascript(). |
&Apache::lonhtmlcommon::dragmath_js("EditMathPopup"); |
&Apache::lonhtmlcommon::dragmath_js("EditMathPopup"); |
my $only_body = ($env{'environment.remote'} eq 'off')? 0 : 1; |
|
my $dragmath_button = |
|
&Apache::lonhtmlcommon::dragmath_button("LC_editxmltext",1); |
|
|
|
# Breadcrumbs |
# Breadcrumbs |
my $brcrum = [{'href' => &Apache::loncommon::authorspace(), |
my $brcrum = [{'href' => &Apache::loncommon::authorspace(), |
Line 936 sub editxmlmode {
|
Line 944 sub editxmlmode {
|
my $start_page = |
my $start_page = |
&Apache::loncommon::start_page(&mt("EditXML [_1]",$file),$js, |
&Apache::loncommon::start_page(&mt("EditXML [_1]",$file),$js, |
{'no_auto_mt_title' => 1, |
{'no_auto_mt_title' => 1, |
'only_body' => $only_body, |
'only_body' => 0, |
'add_entries' => { |
'add_entries' => { |
'onresize' => q[resize_textarea('LC_editxmltext','LC_aftertextarea')], |
'onresize' => q[resize_textarea('LC_editxmltext','LC_aftertextarea')], |
'onload' => q[resize_textarea('LC_editxmltext','LC_aftertextarea')], |
'onload' => q[resize_textarea('LC_editxmltext','LC_aftertextarea')], |
}, |
}, |
'bread_crumbs' => $brcrum, |
'bread_crumbs' => $brcrum, |
}); |
}); |
|
|
$result=$start_page |
$result=$start_page |
.&Apache::loncommon::head_subbox( |
.&Apache::loncommon::head_subbox( |
Line 953 sub editxmlmode {
|
Line 961 sub editxmlmode {
|
&Apache::structuretags::remember_problem_state().' |
&Apache::structuretags::remember_problem_state().' |
<div class="LC_edit_problem_editxml_header"> |
<div class="LC_edit_problem_editxml_header"> |
<table class="LC_edit_problem_header_title"><tr><td> |
<table class="LC_edit_problem_header_title"><tr><td> |
'.&mt('Problem Editing').&Apache::loncommon::help_open_topic('Problem_Editor_XML_Index').' |
<h2>'.&mt('Problem Editing').' '.&Apache::loncommon::help_open_topic('Problem_Editor_XML_Index').'</h2> |
</td><td align="right"> |
</td><td align="right"> |
'.&Apache::loncommon::helpLatexCheatsheet('Problem_LON-CAPA_Functions','Script Functions').' |
'.&Apache::loncommon::helpLatexCheatsheet('Problem_LON-CAPA_Functions','Script Functions').' |
</td></tr> |
</td></tr> |
</table> |
</table>'; |
<div class="LC_edit_problem_discards"> |
|
<input type="hidden" name="problemmode" value="editxml" /> |
$result.='<input type="hidden" name="problemmode" value="saveedit" />'. |
|
&Apache::structuretags::problem_edit_buttons('editxml'); |
<input type="button" name="submitmode" accesskey="d" value="'.&mt('Discard Edits and View').'" '. |
|
'onclick="javascript:setmode(this.form,'."'discard'".')" /> |
$result.='<hr style="clear:both;" />'.&Apache::lonxml::message_location().'</div>'. |
<input type="button" '.&Apache::edit::submit_ask_anyway('setmode(this.form,'."'edit'".')').'name="submitmode" accesskey="e" value="'.&mt('Edit').'" /> |
'<textarea '.&Apache::edit::element_change_detection(). |
<input type="submit" name="Undo" accesskey="u" value="'.&mt('undo').'" /> |
|
'.$dragmath_button.' |
|
</div> |
|
<div class="LC_edit_problem_saves"> |
|
<input type="submit" name="submitbutton" accesskey="s" value="'.&mt('Save').'" /> |
|
<input type="submit" name="submitbutton" accesskey="v" value="'.&mt('Save and View').'" /> |
|
</div> |
|
<hr class="LC_edit_problem_divide" /> |
|
'.&Apache::lonxml::message_location().' |
|
</div> |
|
' . ' |
|
<textarea '.&Apache::edit::element_change_detection(). |
|
' rows="'.$rows.'" cols="'.$cols.'" style="width:100%" '. |
' rows="'.$rows.'" cols="'.$cols.'" style="width:100%" '. |
' name="editxmltext" id="LC_editxmltext">'. |
' name="editxmltext" id="LC_editxmltext">'. |
&HTML::Entities::encode($problem,'<>&"').'</textarea> |
&HTML::Entities::encode($problem,'<>&"').'</textarea> |
Line 1101 sub get_template_list {
|
Line 1097 sub get_template_list {
|
} |
} |
my $count = 0; |
my $count = 0; |
my $currentcategory=''; |
my $currentcategory=''; |
|
my $first = 1; |
foreach my $file (@files) { |
foreach my $file (@files) { |
next if ($file->[1] !~ /\S/); |
next if ($file->[1] !~ /\S/); |
if ($file->[2] ne $currentcategory) { |
if ($file->[2] ne $currentcategory) { |
$currentcategory=$file->[2]; |
$currentcategory=$file->[2]; |
if ((!$seconddiv) && ($count >= $midpoint)) { |
if ((!$seconddiv) && ($count >= $midpoint)) { |
$result .= '</div>'."\n".'<div class="LC_left_float">'."\n"; |
$result .= '</div></div>'."\n".'<div class="LC_left_float">'."\n"; |
$seconddiv = 1; |
$seconddiv = 1; |
|
} elsif (!$first) { |
|
$result.='</div>'."\n"; |
|
} else { |
|
$first = 0; |
} |
} |
$result.='<h3>'.$currentcategory.'</h3>'; |
$result.= '<div class="LC_Box">'."\n" |
|
.'<h3 class="LC_hcell">'.$currentcategory.'</h3>'."\n"; |
$count++; |
$count++; |
} |
} |
$result .= |
$result .= |
Line 1120 sub get_template_list {
|
Line 1122 sub get_template_list {
|
} |
} |
my $filename=$file->[0]; |
my $filename=$file->[0]; |
$filename=~s/^\/home\/httpd\/html//; |
$filename=~s/^\/home\/httpd\/html//; |
$result.=' <font size="-2"><a href="'.$filename.'" target="sample">'.&mt('Example').'</font></a><br />'."\n"; |
$result.=' <span class="LC_fontsize_small">' |
|
.'<a href="'.$filename.'?inhibitmenu=yes" target="sample">'.&mt('Example').'</a>' |
|
.'</span><br />'."\n"; |
$count ++; |
$count ++; |
} |
} |
if ($numfiles > 0) { |
if ($numfiles > 0) { |
$result .= '</div>'."\n".'<div class="LC_clear_float_footer"></div>'."\n"; |
$result .= '</div></div>'."\n".'<div class="LC_clear_float_footer"></div>'."\n"; |
} |
} |
return $result; |
return $result; |
} |
} |
Line 1173 sub newproblem {
|
Line 1177 sub newproblem {
|
.'<h1>'.&mt("Creating a new $extension resource.")."</h1> |
.'<h1>'.&mt("Creating a new $extension resource.")."</h1> |
$errormsg |
$errormsg |
".&mt("The requested file [_1] currently does not exist.", |
".&mt("The requested file [_1] currently does not exist.", |
'<span class="LC_filename">'.$shownurl.'</span>')." |
'<span class="LC_filename">'.$shownurl.'</span>').' |
<p> |
<p class="LC_info"> |
<b> |
'.&mt("To create a new $extension, select a template from the". |
".&mt("To create a new $extension, select a template from the". |
" list below. Then click on the \"Create $extension\" button.").' |
" list below. Then click on the \"Create $extension\" button.").'</b> |
</p><div><form action="'.$url.'" method="post">'); |
</p><form action="'.$url.'" method="post">'); |
|
|
|
if (defined($templatelist)) { |
if (defined($templatelist)) { |
$request->print($templatelist); |
$request->print($templatelist); |
} |
} |
$request->print('<br /><input type="submit" name="newfile" value="'. |
$request->print('<br /><input type="submit" name="newfile" value="'. |
&mt("Create $extension").'" />'); |
&mt("Create $extension").'" />'); |
$request->print("</form></p>".&Apache::loncommon::end_page()); |
$request->print('</form></div>'.&Apache::loncommon::end_page()); |
} |
} |
return; |
return; |
} |
} |
Line 1245 sub handler {
|
Line 1248 sub handler {
|
#first visit to problem in construction space |
#first visit to problem in construction space |
$env{'form.problemmode'}= 'view'; |
$env{'form.problemmode'}= 'view'; |
&renderpage($request,$file); |
&renderpage($request,$file); |
} elsif ($env{'form.problemmode'} eq 'editxml') { |
} elsif (($env{'form.problemmode'} eq 'editxml') || |
|
($env{'form.problemmode'} eq 'saveeditxml') || |
|
($env{'form.problemmode'} eq 'saveviewxml') || |
|
($env{'form.problemmode'} eq 'undoxml')) { |
&editxmlmode($request,$file); |
&editxmlmode($request,$file); |
} elsif ($env{'form.problemmode'} eq 'calcanswers') { |
} elsif ($env{'form.problemmode'} eq 'calcanswers') { |
&analyze($request,$file); |
&analyze($request,$file); |